to be sure that the record being removed is a peer record
[sfa.git] / sfa / methods / remove_peer_object.py
1 from sfa.util.faults import *
2 from sfa.util.method import Method
3 from sfa.util.parameter import Parameter, Mixed
4 from sfa.trust.auth import Auth
5 from sfa.util.record import GeniRecord
6 from sfa.util.genitable import GeniTable
7 from sfa.util.debug import log
8 from sfa.trust.credential import Credential
9 from sfa.util.misc import *
10 from types import StringTypes
11
12 class remove_peer_object(Method):
13     """
14     Remove an peer object from the PLC records of a local aggregate. 
15     This method will be called by registry.remove() while removing 
16     a record from the local aggreage's PLCDB and sfa table. This 
17     method need not be directly called by end-user.
18     
19     @param cred credential string
20     @param record record as stored in the local registry
21
22     @return 1 if successful, faults otherwise 
23     """
24
25     interfaces = ['registry']
26     
27     accepts = [
28         Parameter(str, "Credential string"),
29         Parameter(dict, "Record dictionary")
30         ]
31
32     returns = Parameter(int, "1 if successful")
33     
34     def call(self, cred, record, caller_cred=None):
35         if caller_cred==None:
36             caller_cred=cred
37         #log the call
38         self.api.logger.info("interface: %s\tcaller-hrn: %s\ttarget-hrn: %s\tmethod-name: %s"%(self.api.interface, Credential(string=caller_cred).get_gid_caller().get_hrn(), record['hrn'], self.name))
39         
40         self.api.auth.check(cred, "remove")
41
42         # Only allow the local interface or record owner to delete peer_records 
43         try: self.api.auth.verify_object_permission(record['hrn'])
44         except: self.api.auth.verify_cred_is_me(cred)
45         
46         table = GeniTable()
47         hrn, type = record['hrn'], record['type']
48         records = table.find({'hrn': hrn, 'type': type })
49         for record in records:
50           if record['peer_authority']:
51             self.remove_plc_record(record)
52             table.remove(record)
53             
54         return 1
55
56     def remove_plc_record(self, record):
57         type = record['type']        
58         if type == "user":
59             persons = self.api.plshell.GetPersons(self.api.plauth, {'person_id' : record['pointer']})
60             if not persons:
61                 return 1
62             person = persons[0]
63             if person['peer_id']:
64                 peer = self.get_peer_name(person['peer_id']) 
65                 self.api.plshell.UnBindObjectFromPeer(self.api.plauth, 'person', person['person_id'], peer)
66             self.api.plshell.DeletePerson(self.api.plauth, person['person_id'])
67            
68         elif type == "slice":
69             slices=self.api.plshell.GetSlices(self.api.plauth, {'slice_id' : record['pointer']})
70             if not slices:
71                 return 1
72             slice=slices[0]
73             if slice['peer_id']:
74                 peer = self.get_peer_name(slice['peer_id']) 
75                 self.api.plshell.UnBindObjectFromPeer(self.api.plauth, 'slice', slice['slice_id'], peer)
76             self.api.plshell.DeleteSlice(self.api.plauth, slice['slice_id'])
77         elif type == "authority":
78             sites=self.api.plshell.GetSites(self.api.plauth, {'site_id' : record['pointer']})
79             if not sites:
80                 return 1
81             site=sites[0]
82             if site['peer_id']:
83                 peer = self.get_peer_name(site['peer_id']) 
84                 self.api.plshell.UnBindObjectFromPeer(self.api.plauth, 'site', site['site_id'], peer)
85             self.api.plshell.DeleteSite(self.api.plauth, site['site_id'])
86            
87         else:
88             raise UnknownGeniType(type)
89
90         return 1
91
92     def get_peer_name(self, peer_id):
93         peers = self.api.plshell.GetPeers(self.api.plauth, [peer_id], ['peername', 'shortname', 'hrn_root'])
94         if not peers:
95             raise GeniInvalidArgument, "No such peer"
96         peer = peers[0]
97         return peer['shortname'] 
98
99
100