Definição
db.grantRolesToUser(username, roles, writeConcern)Concede funções adicionais a um usuário.
O método
db.grantRolesToUser()utiliza a seguinte sintaxe:db.grantRolesToUser( "<username>", [ <roles> ], { <writeConcern> } ) O método
db.grantRolesToUser()utiliza os seguintes argumentos:ParâmetroTipoDescriçãouserstring
O nome do usuário a quem conceder funções.
rolesarray
Uma série de funções adicionais a serem concedidas ao usuário.
writeConcerndocumento
Opcional. O nível de preocupação de gravação para a operação. Consulte Especificação de write concern.
No campo
roles, é possível especificar roles incorporadas e roles definidas pelo usuário.Para especificar uma função que existe no mesmo banco de dados onde o
db.grantRolesToUser()é executado, você pode especificar a função com o próprio nome dela:"readWrite" Ou você pode especificar a role com um documento, como feito a seguir:
{ role: "<role>", db: "<database>" } Para especificar uma role existente em outro banco de dados, especifique-a com um documento.
O método
db.grantRolesToUser()encapsula o comandograntRolesToUser.
Compatibilidade
Esse método está disponível em implantações hospedadas nos seguintes ambientes:
Importante
Este comando não é suportado em clusters MongoDB Atlas . Para obter informações sobre o suporte do Atlas para todos os comandos, consulte Comandos não suportados.
MongoDB Enterprise: a versão autogerenciada e baseada em assinatura do MongoDB
MongoDB Community: uma versão com código disponível, de uso gratuito e autogerenciada do MongoDB
Comportamento
réplicaSet
Se executado em um conjunto de réplicas, db.grantRolesToUser() é executado usando a preocupação de gravação "majority" por padrão.
Acesso necessário
Você deve ter grantRole como uma ação em um banco de dados para conceder uma função neste banco de dados.
Exemplo
Dado um usuário accountUser01 no banco de dados do products com os seguintes roles:
"roles" : [ { "role" : "assetsReader", "db" : "assets" } ]
A operação db.grantRolesToUser() a seguir fornece a accountUser01 a função readWrite no banco de dados products e a função read no banco de dados stock.
use products db.grantRolesToUser( "accountUser01", [ "readWrite" , { role: "read", db: "stock" } ], { w: "majority" , wtimeout: 4000 } )
O usuário accountUser01 no banco de dados de products agora tem os seguintes roles:
"roles" : [ { "role" : "assetsReader", "db" : "assets" }, { "role" : "read", "db" : "stock" }, { "role" : "readWrite", "db" : "products" } ]