D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
proc
/
self
/
root
/
opt
/
saltstack
/
salt
/
lib
/
python3.10
/
site-packages
/
salt
/
states
/
Filename :
keystone_user.py
back
Copy
""" Management of OpenStack Keystone Users ====================================== .. versionadded:: 2018.3.0 :depends: shade :configuration: see :py:mod:`salt.modules.keystoneng` for setup instructions Example States .. code-block:: yaml create user: keystone_user.present: - name: user1 delete user: keystone_user.absent: - name: user1 create user with optional params: keystone_user.present: - name: user1 - domain: domain1 - enabled: False - password: password123 - email: "user1@example.org" - description: 'my user' """ __virtualname__ = "keystone_user" def __virtual__(): if "keystoneng.user_get" in __salt__: return __virtualname__ return ( False, "The keystoneng execution module failed to load: shade python module is not" " available", ) def _common(kwargs): """ Returns: None if user wasn't found, otherwise a user object """ search_kwargs = {"name": kwargs["name"]} if "domain" in kwargs: domain = __salt__["keystoneng.get_entity"]("domain", name=kwargs.pop("domain")) domain_id = domain.id if hasattr(domain, "id") else domain search_kwargs["domain_id"] = domain_id kwargs["domain_id"] = domain_id return __salt__["keystoneng.user_get"](**search_kwargs) def present(name, auth=None, **kwargs): """ Ensure domain exists and is up-to-date name Name of the domain domain The name or id of the domain enabled Boolean to control if domain is enabled description An arbitrary description of the domain password The user password email The users email address """ ret = {"name": name, "changes": {}, "result": True, "comment": ""} kwargs = __utils__["args.clean_kwargs"](**kwargs) __salt__["keystoneng.setup_clouds"](auth) kwargs["name"] = name user = _common(kwargs) if user is None: if __opts__["test"] is True: ret["result"] = None ret["changes"] = kwargs ret["comment"] = "User will be created." return ret user = __salt__["keystoneng.user_create"](**kwargs) ret["changes"] = user ret["comment"] = "Created user" return ret changes = __salt__["keystoneng.compare_changes"](user, **kwargs) if changes: if __opts__["test"] is True: ret["result"] = None ret["changes"] = changes ret["comment"] = "User will be updated." return ret kwargs["name"] = user __salt__["keystoneng.user_update"](**kwargs) ret["changes"].update(changes) ret["comment"] = "Updated user" return ret def absent(name, auth=None, **kwargs): """ Ensure user does not exists name Name of the user domain The name or id of the domain """ ret = {"name": name, "changes": {}, "result": True, "comment": ""} kwargs = __utils__["args.clean_kwargs"](**kwargs) __salt__["keystoneng.setup_clouds"](auth) kwargs["name"] = name user = _common(kwargs) if user: if __opts__["test"] is True: ret["result"] = None ret["changes"] = {"id": user.id} ret["comment"] = "User will be deleted." return ret __salt__["keystoneng.user_delete"](name=user) ret["changes"]["id"] = user.id ret["comment"] = "Deleted user" return ret