1 # Thierry Parmentelat <thierry.parmentelat@inria.fr>
2 # Copyright (C) 2010 INRIA
11 def __init__ (self,test_auth_sfa, user_spec):
12 self.test_auth_sfa=test_auth_sfa
13 self.user_spec=user_spec
15 self.test_plc=self.test_auth_sfa.test_plc
16 self.login_base=self.test_auth_sfa.login_base
18 def sfi_path(self): return self.test_auth_sfa.sfi_path()
19 def qualified(self,name): return self.test_auth_sfa.qualified(name)
20 def sfi_pi(self,*args,**kwds): return self.test_auth_sfa.sfi_pi(*args, **kwds)
21 def sfi_user(self,*args,**kwds): return self.test_auth_sfa.sfi_user(*args, **kwds)
23 # xxx todo - not the right place any longer - or is it ?
24 def sfa_add_user (self,options):
25 "add a regular user using sfi add"
26 user_hrn = self.qualified(self.user_spec['name'])
28 command += " --type user"
29 command += " --xrn %s"%user_hrn
30 command += " --email %s"%self.user_spec['email']
31 command += " " + " ".join(self.user_spec['add_options'])
32 # handle key separately because of embedded whitespace
33 # hack - the user's pubkey is avail from his hrn
34 command += " -k %s/%s.pub"%(self.sfi_path(),user_hrn)
35 return self.test_plc.run_in_guest(self.sfi_pi(command))==0
37 def sfa_update_user (self,options):
38 "update a user record using sfi update"
39 user_hrn = self.qualified(self.user_spec['name'])
41 command += " --type user"
42 command += " --xrn %s"%user_hrn
43 command += " " + " ".join(self.user_spec['update_options'])
44 return self.test_plc.run_in_guest(self.sfi_pi(command))==0
46 def sfa_delete_user(self,options):
47 "run sfi delete on user record"
48 user_hrn = self.qualified(self.user_spec['name'])
49 command="remove -t user %s"%user_hrn
51 self.test_plc.run_in_guest(self.sfi_pi(command))==0