+
+# Convert a lat/long attribute into Decimal degrees
+def DecDegree(Posn,Anon=0):
+ Parts = re.match('[+-]?(\d*)\\.?(\d*)?',Posn).groups();
+ Val = string.atof(Posn);
+
+ if (abs(Val) >= 1806060.0):
+ raise ValueError,"Too Big";
+
+ # Val is in DGMS
+ if abs(Val) >= 18060.0 or len(Parts[0]) > 5:
+ Val = Val/100.0;
+ Secs = Val - long(Val);
+ Val = long(Val)/100.0;
+ Min = Val - long(Val);
+ Val = long(Val) + (Min*100.0 + Secs*100.0/60.0)/60.0;
+
+ # Val is in DGM
+ elif abs(Val) >= 180 or len(Parts[0]) > 3:
+ Val = Val/100.0;
+ Min = Val - long(Val);
+ Val = long(Val) + Min*100.0/60.0;
+
+ if Anon != 0:
+ Str = "%3.2f"%(Val);
+ else:
+ Str = str(Val);
+ if Val >= 0:
+ return "+" + Str;
+ return Str;
+
+def FormatSSHAuth(Str):
+ Match = SSHAuthSplit.match(Str);
+ if Match == None:
+ return "<unknown format>";
+ G = Match.groups();
+
+ # No options
+ if G[0] == None:
+ return "%s %s %s..%s %s"%(G[1],G[2],G[3][:8],G[3][-8:],G[4]);
+ return "%s %s %s %s..%s %s"%(G[0],G[1],G[2],G[3][:8],G[3][-8:],G[4]);
+
+def FormatPGPKey(Str):
+ Res = "";
+
+ # PGP 2.x Print
+ if (len(Str) == 32):
+ I = 0;
+ while (I < len(Str)):
+ if I+2 == 32/2:
+ Res = "%s %s%s "%(Res,Str[I],Str[I+1]);
+ else:
+ Res = "%s%s%s "%(Res,Str[I],Str[I+1]);
+ I = I + 2;
+ elif (len(Str) == 40):
+ # OpenPGP Print
+ I = 0;
+ while (I < len(Str)):
+ if I+4 == 40/2:
+ Res = "%s %s%s%s%s "%(Res,Str[I],Str[I+1],Str[I+2],Str[I+3]);
+ else:
+ Res = "%s%s%s%s%s "%(Res,Str[I],Str[I+1],Str[I+2],Str[I+3]);
+ I = I + 4;
+ else:
+ Res = Str;
+ return string.strip(Res);
+
+# Take an email address and split it into 3 parts, (Name,UID,Domain)
+def SplitEmail(Addr):
+ Res1 = rfc822.AddrlistClass(Addr).getaddress();
+ if len(Res1) != 1:
+ return ("","",Addr);
+ Res1 = Res1[0];
+ if Res1[1] == None:
+ return (Res1[0],"","");
+ Res2 = string.split(Res1[1],"@");
+ if len(Res2) != 2:
+ return (Res1[0],"",Res1[1]);
+ return (Res1[0],Res2[0],Res2[1]);