C# Azure DocumentDB 授权密钥权限

C# Azure DocumentDB Authorization Key Permissions

我想知道是否有办法确定连接到 Azure DocumentDB 时使用的授权密钥的级别。

主要是为了防止在提供只读授权密钥时尝试创建文档或修改文档。

类似于

static async void LogIn(string url, string authKey)
{
    DocumentClient client = new DocumentClient(new Uri(url), authKey);
    if(?clientpermissions?== PermissionMode.Read)
    { Console.WriteLine("You are in read-only mode."); }
}

我看到用户 class 有一个可以访问的权限对象,但是当纯粹使用 auth 密钥时我有点迷茫。

我曾考虑尝试创建一个文档并查看是否有异常,但我真的不喜欢使用失败作为条件似乎是一种不好的做法。

这里的目标是一种管理文档数据库的工具(我知道有一些已经存在,这更多是对我技能的练习)。因此,沿着这些思路说,有人试图使用他们获得的密钥访问数据库,他们可能会或可能不会获得 rw 密钥,其中他们也可能不知道权限。理想情况下,可以显示标签或指示器来说明他们的访问级别。 谢谢!

客户端是用授权密钥构建的,此时没有比您更多的信息。它只是一个字符串。

您可以利用 DocumentClient.ReadPermissionAsync 方法来获取资源的权限。我还没有亲身尝试过,但探索一下可能会很好。

但是,您不妨尝试 read/write 您正在寻找的原始文档,并在适用时由于权限有限而捕获异常。这是因为您无论如何都需要发出请求才能获得权限。

我不知道你为什么要做你正在做的事情,但是,我会退后一步问问自己,你是否可以确保你拥有 [=21] 的正确密钥=] 你想做的操作。

HTH