# -*- mode: python -*-
# This script is an interactive way to manipulate fields in the LDAP directory.
# When run it connects to the directory using the current users ID and fetches
-# all the attributes for the first machine. It then formats them nicely and
+# all the attributes for the first machine. It then formats them nicely and
# allows the user to change them.
#
# Usage: userinfo -a <user> -u <user> -c <user> -r
-# -a Set the authentication user (the user whose password you are
+# -a Set the authentication user (the user whose password you are
# going to enter)
# -h Set the host to display
"machine": ["Machine Hardware", 10],
"memory": ["Memory", 11],
"disk": ["Disk", 12],
- "sshrsahostkey": ["SSH RSA", 14],
- "sshdsahostkey": ["SSH DSA", 15],
- "bandwidth": ["Bandwidth", 16]};
+ "sshrsahostkey": ["SSH Host Keys", 14],
+ "bandwidth": ["Bandwidth", 15]};
AttrPrompt = {"description": ["Purpose of the machine"],
"hostname": ["The hostnames for the box (ipv4/ipv6)"],
"machine": ["Hardware description"],
"memory": ["Installed RAM"],
"disk": ["Disk Space, RAID levels, etc"],
- "sshrsahostkey": ["A copy of /etc/ssh/ssh_host_key.pub"],
- "sshdsahostkey": ["A copy of /etc/ssh/ssh_host_key.pub.dsa"],
+ "sshrsahostkey": ["A copy of /etc/ssh/ssh_*host_key.pub"],
"bandwidth": ["Available outbound"]};
# Create a map of IDs to desc,value,attr
print;
else:
OrderedIndex[AttrInfo[at][1]][1] = Attrs[1][at];
-
+
Keys = OrderedIndex.keys();
Keys.sort();
for at in Keys:
# Change a single attribute
def ChangeAttr(Attrs,Attr):
- if (Attr == "sponsor" or Attr == "hostname"):
+ if (Attr == "sponsor" or Attr == "hostname" or Attr == "sshrsahostkey"):
return MultiChangeAttr(Attrs,Attr);
print "Old value: '%s'" % (GetAttr(Attrs,Attr,""));
print "Press enter to leave unchanged and a single space to set to empty";
NewValue = raw_input("New? ");
-
+
# Empty string
if (NewValue == ""):
print "Leaving unchanged.";
if (NewValue == ""):
print "Leaving unchanged.";
return;
-
- # Delete
+
+ # Delete
if (Mode == "D"):
print "Deleting.",;
try:
l.simple_bind_s(UserDn,Password);
else:
l.simple_bind_s("","");
-
-HBaseDn = "ou=hosts,dc=debian,dc=org";
+
+HBaseDn = "ou=hosts,dc=debian,dc=org";
HostDn = "host=" + Host + "," + HBaseDn;
# Query the server for all of the attributes
Attrs = l.search_s(HBaseDn,ldap.SCOPE_ONELEVEL,"host=" + Host);
if len(Attrs) == 0:
print "Host",Host,"was not found.";
- sys.exit(0);
+ sys.exit(0);
# repeatedly show the account configuration
while(1):
if RootMode == 1:
print " a) Arbitary Change";
print " n) New Host";
+ print " d) Delete Host";
print " u) Switch Hosts";
print " x) Exit";
-
+
# Prompt
Response = raw_input("Change? ");
if (Response == "x" or Response == "X" or Response == "q" or
Dn = "host=" + NewHost + "," + HBaseDn;
l.add_s(Dn,[("host",NewHost),
("objectclass","top")]);
-
- # Switch
+
+ # Switch
NAttrs = l.search_s(HBaseDn,ldap.SCOPE_ONELEVEL,"host=" + NewHost);
if len(NAttrs) == 0:
print "Host",NewHost,"was not found.";
HostDn = "host=" + Host + "," + HBaseDn;
OrderedIndex = copy.deepcopy(OrigOrderedIndex);
continue;
-
+
# Handle changing an arbitary value
if (Response == "a"):
Attr = raw_input("Attr? ");
ChangeAttr(Attrs[0],Attr);
continue;
+ if (Response == 'd'):
+ Really = raw_input("Really (type yes)? ");
+ if Really != 'yes':
+ continue;
+ print "Deleting",HostDn;
+ l.delete_s(HostDn);
+ continue;
+
# Convert the integer response
try:
ID = int(Response);