from PLC.Faults import *
from PLC.Parameter import Parameter, Mixed, python_type, xmlrpc_type
from PLC.Auth import Auth
+from PLC.Timestamp import Timestamp
from PLC.Debug import profile
-from PLC.Events import Event, Events
from PLC.Nodes import Node, Nodes
from PLC.Persons import Person, Persons
password=auth['AuthString'],
tenant=auth['Tenant'])
self.api.client_shell.authenticate()
- self.caller = self.api.client_shell.keystone.users.find(name=auth['Username'])
+ self.caller = Person(self.api, object=self.api.client_shell.keystone.users.find(name=auth['Username']))
self.caller_tenant = self.api.client_shell.keystone.tenants.find(name=auth['Tenant'])
caller_roles = self.api.client_shell.keystone.roles.roles_for_user(self.caller, self.caller_tenant)
role_names = [role.name for role in caller_roles]
+ self.caller['roles'] = role_names
if not set(role_names).intersection(self.roles):
method_message="method %s has roles [%s]"%(self.name,','.join(self.roles))
person_message="caller %s has roles [%s]"%(self.caller.name,','.join(role_names))