1

在 Go 中,我将一个用户添加到 mongo 并希望创建一个角色,该角色仅授予对特定集合的访问权限。我是 mongo 的新手,所以不知道该怎么做。我的尝试是使用 RunCommand。以下是我尝试过的,但我得到一个:
运行时错误:无效的内存地址或零指针取消引用

在我的代码下面,我验证了 database 和 id 的值是否设置正确。

createRoleResult := client.Database(db).RunCommand(ctx, bson.D{{"createRole", id},
        {"privileges", []bson.M{
            {
                "resource": bson.A{bson.M{"db": db}, bson.M{"collection": id}, bson.M{"actions": bson.A{"update", "insert", "remove"}}},
            },
    }}})

此代码的结果相同:

    createRoleResult := client.Database(db).RunCommand(ctx, bson.D{{"createRole", id},
        {"privileges", []bson.A{
            {
                bson.D{bson.E{"resource", bson.A{bson.D{bson.E{"db", db}}, bson.D{bson.E{"collection", id}}, bson.E{"actions", bson.A{"update", "insert", "remove"}}}}},
            },
        }}})

任何意见,将不胜感激!如果有更好的方法来解决这个问题,我会全力以赴。

工作外壳代码:

db.createRole(
   {
     role: "ABC",
     privileges: [
       { resource: { db: "MyDB", collection: "ABC" }, actions: [ "update", "insert", "remove", "find" ] }
     ],
     roles: []
   }
)

谢谢!

4

1 回答 1

0

你可以试试这个 Golang 代码:

var commandResult bson.M
command := bson.D{{ "createRole", "ABC" }, { "privileges", bson.A{ bson.D{{ "resource", bson.D{{ "db", "MyDB" }, { "collection", "ABC" }}}, { "actions", bson.A{ "update", "insert" }}}}}, { "roles", bson.A{}}}
err = client.Database("test").RunCommand(context.TODO(), command).Decode(&commandResult)

if err != nil {
    log.Fatal(err)
}

fmt.Println(commandResult)
于 2022-02-21T19:22:46.657 回答