36.15. 使用 Ansible 授予 IdM 组访问 IdM 客户端上声卡的权限
您可以使用 ansible-freeipa
idview
和 idoverridegroup
模块,使身份管理(IdM)或活动目录(AD)用户成为 IdM 客户端上本地 audio
组的成员。这授予 IdM 或 AD 用户对主机上声卡的特权访问。
该流程使用 idview_for_host01 ID 视图的示例,其使用 GID
63 添加 音频 ID 覆盖,它与 RHEL 主机上本地 音频
组的 GID 对应。idview_for_host01 ID 视图被应用到名为 host01.idm.example.com 的 IdM 客户端。
先决条件
您已配置了 Ansible 控制节点以满足以下要求:
- 您在使用 Ansible 版本 2.15 或更高版本。
-
已安装
freeipa.ansible_freeipa
集合。 - 示例假定在 ~/MyPlaybooks/ 目录中,您已创建了一个具有 IdM 服务器的完全限定域名(FQDN)的 Ansible 清单文件。
-
示例假定 secret.yml Ansible vault 存储了您的
ipaadmin_password
,并且您可以访问存储了保护 secret.yml 文件的密码的文件。
-
目标节点(这是执行
freeipa.ansible_freeipa
模块的节点)是作为 IdM 客户端、服务器或副本的 IdM 域的一部分。
*getent group audio*
$ *getent group audio*
---------------------
audio:x:63
在 Ansible 控制节点上,使用以下任务创建一个 give-idm-group-access-to-sound-card-on-idm-client.yml playbook:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 保存该文件。
运行 Ansible playbook。指定 playbook 文件、存储保护 secret.yml 文件的密码,以及清单文件:
ansible-playbook --vault-password-file=password_file -v -i inventory give-idm-group-access-to-sound-card-on-idm-client.yml
$ ansible-playbook --vault-password-file=password_file -v -i inventory give-idm-group-access-to-sound-card-on-idm-client.yml
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
验证
在 IdM 客户端上,获取 IdM 管理员的凭证:
kinit admin
$ kinit admin Password:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 创建一个 test IdM 用户:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 将用户添加到 IdM audio 组中:
ipa group-add-member --tuser audio
$ ipa group-add-member --tuser audio
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 以 tuser 用户身份登录到 host01.idm.example.com:
ssh tuser@host01.idm.example.com
$ ssh tuser@host01.idm.example.com
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 验证用户的组成员资格:
id tuser
$ id tuser uid=702801456(tuser) gid=63(audio) groups=63(audio)
Copy to Clipboard Copied! Toggle word wrap Toggle overflow