Permissions class
用于创建、替换、查询和读取所有权限。
请参阅 权限 按 ID 读取、替换或删除特定权限。
属性
user |
方法
create(Permission |
创建权限。 权限表示访问特定资源(例如项或容器)的按用户权限。 示例
|
query(Sql |
查询所有权限。 示例 具有 id 的 Query 权限。
|
query<T>(Sql |
查询所有权限。 |
read |
读取所有权限。 示例 读取数组的所有权限。
|
upsert(Permission |
向上插入权限。 权限表示访问特定资源(例如项或容器)的按用户权限。 示例
|
属性详细信息
user
方法详细信息
create(PermissionDefinition, RequestOptions)
创建权限。
权限表示访问特定资源(例如项或容器)的按用户权限。
示例
import { CosmosClient, PermissionDefinition, PermissionMode } from "@azure/cosmos";
const endpoint = "https://your-account.documents.azure.com";
const key = "<database account masterkey>";
const client = new CosmosClient({ endpoint, key });
const { database } = await client.databases.createIfNotExists({ id: "Test Database" });
const { user } = await database.users.create({ id: "<user-id>" });
const permissionDefinition: PermissionDefinition = {
id: "<permission-id>",
permissionMode: PermissionMode.Read,
resource: "<resource-url>",
};
await user.permissions.create(permissionDefinition);
function create(body: PermissionDefinition, options?: RequestOptions): Promise<PermissionResponse>
参数
- body
- PermissionDefinition
表示权限的正文。
- options
- RequestOptions
返回
Promise<PermissionResponse>
query(SqlQuerySpec, FeedOptions)
查询所有权限。
示例
具有 id 的 Query 权限。
import { CosmosClient, SqlQuerySpec } from "@azure/cosmos";
const endpoint = "https://your-account.documents.azure.com";
const key = "<database account masterkey>";
const client = new CosmosClient({ endpoint, key });
const { database } = await client.databases.createIfNotExists({ id: "Test Database" });
const querySpec: SqlQuerySpec = {
query: `SELECT * FROM root r WHERE r.id = @permission`,
parameters: [{ name: "@permission", value: "<permission-id>" }],
};
const { resources: permisssion } = await database
.user("<user-id>")
.permissions.query(querySpec)
.fetchAll();
function query(query: SqlQuerySpec, options?: FeedOptions): QueryIterator<any>
参数
- query
- SqlQuerySpec
作的查询配置。 有关如何配置查询的详细信息,请参阅 SqlQuerySpec。
- options
- FeedOptions
返回
QueryIterator<any>
query<T>(SqlQuerySpec, FeedOptions)
查询所有权限。
function query<T>(query: SqlQuerySpec, options?: FeedOptions): QueryIterator<T>
参数
- query
- SqlQuerySpec
作的查询配置。 有关如何配置查询的详细信息,请参阅 SqlQuerySpec。
- options
- FeedOptions
返回
readAll(FeedOptions)
读取所有权限。
示例
读取数组的所有权限。
import { CosmosClient } from "@azure/cosmos";
const endpoint = "https://your-account.documents.azure.com";
const key = "<database account masterkey>";
const client = new CosmosClient({ endpoint, key });
const { database } = await client.databases.createIfNotExists({ id: "Test Database" });
const { resources: permissionList } = await database.user("user1").permissions.readAll().fetchAll();
function readAll(options?: FeedOptions): QueryIterator<PermissionDefinition & Resource>
参数
- options
- FeedOptions
返回
upsert(PermissionDefinition, RequestOptions)
向上插入权限。 权限表示访问特定资源(例如项或容器)的按用户权限。
示例
import { CosmosClient, PermissionDefinition, PermissionMode } from "@azure/cosmos";
const endpoint = "https://your-account.documents.azure.com";
const key = "<database account masterkey>";
const client = new CosmosClient({ endpoint, key });
const { database } = await client.databases.createIfNotExists({ id: "Test Database" });
const user = database.user("<user-id>");
const permissionDefinitionToUpsert: PermissionDefinition = {
id: "<permission-id>",
permissionMode: PermissionMode.Read,
resource: "<resource-url>",
};
await user.permissions.upsert(permissionDefinitionToUpsert);
function upsert(body: PermissionDefinition, options?: RequestOptions): Promise<PermissionResponse>
参数
- body
- PermissionDefinition
- options
- RequestOptions
返回
Promise<PermissionResponse>