X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=PLC%2FAccessors%2FAccessors_standard.py;h=08675157c1666723c4a5a00aaf99e5decdd035c5;hb=053fd6410f733aef90482cda571059ed116d40e1;hp=680dfd51d84f44320f4fc20f5a04f130b1194263;hpb=ddedc20125117fa2f687468b12afae80a3a08b1d;p=plcapi.git diff --git a/PLC/Accessors/Accessors_standard.py b/PLC/Accessors/Accessors_standard.py index 680dfd5..0867515 100644 --- a/PLC/Accessors/Accessors_standard.py +++ b/PLC/Accessors/Accessors_standard.py @@ -4,10 +4,8 @@ from PLC.Nodes import Node from PLC.Interfaces import Interface from PLC.Slices import Slice -from PLC.Slices import Slice from PLC.Sites import Site from PLC.Persons import Person -#from PLC.Ilinks import Ilink from PLC.Accessors.Factory import define_accessors, admin_roles, all_roles, tech_roles @@ -26,33 +24,32 @@ current_module = sys.modules[__name__] ### slice vref define_accessors(current_module, Slice, "Vref", "vref", "slice/config", "vserver reference image name", + set_roles=["admin","pi","user","node"], expose_in_api=True) +# this contains the actual script text +# if set, it supersedes 'initscript' +define_accessors(current_module, Slice, "InitscriptCode","initscript_code", + "slice/usertools", "Slice initialization script code", set_roles=["admin","pi","user"], expose_in_api=True) +# this may contain a *name* that refers to the GetInitScripts +# it was initially designed to share scripts among slices define_accessors(current_module, Slice, "Initscript","initscript", - "slice/usertools", "Slice initialization script", + "slice/usertools", "Slice initialization script name", set_roles=["admin","pi","user"], expose_in_api=True) -# xxx the accessor factory should enforce the category, descriptions and roles provided here. # BootManager might need to set any of these 3, so 'node' needs to be in set_roles -define_accessors(current_module, Slice, "Arch", "arch", +# needs 'pi' and 'tech' for managing their node +# needs 'user' for managing their slices +# needs 'admin' so the Set method is accessible +define_accessors(current_module, [Slice,Node], "Arch", "arch", "node/slice/config", "node arch or slivers arch", - set_roles=["pi","user","tech","node"], expose_in_api=True) -define_accessors(current_module, Slice, "Pldistro", "pldistro", + set_roles=["admin","pi","user","tech","node"], expose_in_api=True) +define_accessors(current_module, [Slice,Node], "Pldistro", "pldistro", "node/slice/config", "PlanetLab distribution to use for node or slivers", - set_roles=["pi","user","tech","node"], expose_in_api=True) -define_accessors(current_module, Slice, "Fcdistro", "fcdistro", + set_roles=["admin","pi","user","tech","node"], expose_in_api=True) +define_accessors(current_module, [Slice,Node], "Fcdistro", "fcdistro", "node/slice/config", "Fedora or CentOS distribution to use for node or slivers", - set_roles=["pi","user","tech","node"], expose_in_api=True) + set_roles=["admin","pi","user","tech","node"], expose_in_api=True) -# Ditto for the GetNodeFlavour method -define_accessors(current_module, Node, "Arch", "arch", - "node/slice/config", "node arch or slivers arch", - set_roles=["pi","user","tech"], expose_in_api=True) -define_accessors(current_module, Node, "Pldistro", "pldistro", - "node/slice/config", "PlanetLab distribution to use for node or slivers", - set_roles=["pi","user","tech"], expose_in_api=True) -define_accessors(current_module, Node, "Fcdistro", "fcdistro", - "node/slice/config", "Fedora or CentOS distribution to use for node or slivers", - set_roles=["pi","user","tech"], expose_in_api=True) # node deployment (alpha, beta, ...) define_accessors(current_module, Node, "Deployment", "deployment", "node/operation", 'typically "alpha", "beta", or "production"',