Docs Menu
Docs Home
/ /

db.grantRolesToUser() (método mongosh)

db.grantRolesToUser(username, roles, writeConcern)

Otorga roles adicionales a un usuario.

Importante

Método mongosh

Esta página documenta una mongosh Método. Esta no es la documentación para comandos de base de datos ni para controladores específicos del lenguaje, como Node.js.

Para el comando de base de datos, consulte el grantRolesToUser dominio.

Para los drivers de API de MongoDB, consulte la documentación del driver de MongoDB específica del lenguaje.

El método utiliza la siguiente db.grantRolesToUser() sintaxis:

db.grantRolesToUser( "<username>", [ <roles> ], { <writeConcern> } )

El método toma los siguientes db.grantRolesToUser() argumentos:

Parameter
Tipo
Descripción

user

string

El nombre del usuario al que se le van a conceder los roles.

roles

arreglo

Una serie de roles adicionales para otorgar al usuario.

writeConcern

Documento

En el campo roles, puede especificar tanto roles de funcionalidad incorporada como roles definidos por el usuario.

Para especificar un rol que existe en la misma base de datos donde se ejecuta db.grantRolesToUser(), puedes especificar el rol utilizando el nombre del rol:

"readWrite"

O puede especificar el rol con un documento, como en:

{ role: "<role>", db: "<database>" }

Para especificar un rol que existe en una base de datos diferente, especifique el rol mediante un documento.

El método db.grantRolesToUser() envuelve el comando grantRolesToUser.

Este método está disponible en implementaciones alojadas en los siguientes entornos:

Importante

Este comando no es compatible con los clústeres de MongoDB Atlas. Para obtener información sobre el soporte de Atlas para todos los comandos, consulta Comandos no compatibles.

  • MongoDB Enterprise: La versión basada en suscripción y autogestionada de MongoDB

  • MongoDB Community: La versión de MongoDB con código fuente disponible, de uso gratuito y autogestionada.

Si se ejecuta en un set de réplicas, db.grantRolesToUser() se ejecuta utilizando el nivel de confirmación de escritura "majority" por defecto.

Debes tener la grantRole acción en una base de datos para conceder un rol en esa base de datos.

Dado un usuario accountUser01 en la base de datos products con los siguientes roles:

"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
}
]

La siguiente operación db.grantRolesToUser() accountUser01 le otorga a readWrite el products rol en la base de datos y read el stock rol en la base de datos.

use products
db.grantRolesToUser(
"accountUser01",
[ "readWrite" , { role: "read", db: "stock" } ],
{ w: "majority" , wtimeout: 4000 }
)

El usuario accountUser01 en la base de datos products ahora tiene los siguientes roles:

"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
},
{ "role" : "read",
"db" : "stock"
},
{ "role" : "readWrite",
"db" : "products"
}
]

Volver

db.getUsers

En esta página