from PLC.Auth import Auth
can_update = lambda (field, value): field in \
- ['name', 'abbreviated_name',
+ ['name', 'abbreviated_name', 'login_base',
'is_public', 'latitude', 'longitude', 'url',
'max_slices', 'max_slivers']
updated, all other fields are left untouched.
PIs can only update sites they are a member of. Only admins can
- update max_slices.
+ update max_slices, max_slivers, and login_base.
Returns 1 if successful, faults otherwise.
"""
returns = Parameter(int, '1 if successful')
+ object_type = 'Site'
+
def call(self, auth, site_id_or_login_base, site_fields):
site_fields = dict(filter(can_update, site_fields.items()))
sites = Sites(self.api, [site_id_or_login_base])
if not sites:
raise PLCInvalidArgument, "No such site"
-
site = sites[0]
+ if site['peer_id'] is not None:
+ raise PLCInvalidArgument, "Not a local site"
+
# Authenticated function
assert self.caller is not None
if site['site_id'] not in self.caller['site_ids']:
raise PLCPermissionDenied, "Not allowed to modify specified site"
- if 'max_slices' or 'max_slivers' in site_fields:
- raise PLCInvalidArgument, "Only admins can update max_slices and max_slivers"
+ # Remove admin only fields
+ for key in 'max_slices', 'max_slivers', 'login_base':
+ del site_fields[key]
site.update(site_fields)
site.sync()
+ # Logging variables
+ self.object_ids = [site['site_id']]
+ self.message = 'Site %d updated: %s' % \
+ (site['site_id'], ", ".join(site_fields.keys()))
+
return 1