【发布时间】:2018-08-20 14:22:14
【问题描述】:
我们在 Windows 环境中运行 RabbitMQ 3.6.5 并使用 LDAP 插件。这允许我们的开发人员查看队列并检查消息。默认情况下,RabbitMQ LDAP 插件允许“所有用户访问所有虚拟主机中的所有对象”(如documented here)。这包括直接从 LDAP 插件发布消息的能力。我们想要做的是拒绝 LDAP 用户的此权限,同时仍然允许他们查看队列。
根据LDAP plugin page,这是通过将 Erlang 查询插入 RabbitMQ 配置来完成的。使用该页面上的示例,我们首先尝试使用此查询简单地授予读取权限(LDAP 细节已更改):
{resource_access_query,
{for, [{permission, configure, {in_group, "OU=someGroup,OU=Departments,OU=ABC,DC=ABC,DC=ORG"}},
{permission, read, {constant, true}}
]
}}
如果没有效果,我们尝试明确拒绝写入权限:
{resource_access_query,
{for, [{resource, queue, {for, [{permission, configure,
{in_group, "OU=someGroup,OU=Departments,OU=ABC,DC=ABC,DC=ORG"}
},
{permission, write, {constant, false}},
{permission, read, {constant, true}}
]}},
]}}
不幸的是,这也没有效果。在这两种情况下,LDAP 用户仍然能够在 LDAP 插件中发布消息。
有人知道我们缺少什么吗?
【问题讨论】: