56 lines
1.9 KiB
JavaScript
56 lines
1.9 KiB
JavaScript
'use strict'
|
|
const root = require( 'app-root-path' )
|
|
const { ApolloError, AuthenticationError, UserInputError } = require( 'apollo-server-express' )
|
|
const { createUser, getUser, getUserRole, updateUser, deleteUser, validatePasssword, createToken, revokeToken, revokeTokenById, validateToken, getUserTokens } = require( '../../services/users' )
|
|
const { validateServerRole, validateScopes, authorizeResolver } = require( `${root}/modules/shared` )
|
|
const setupCheck = require( `${root}/setupcheck` )
|
|
|
|
module.exports = {
|
|
Query: {
|
|
async user( parent, args, context, info ) {
|
|
await validateServerRole( context, 'server:user' )
|
|
await validateScopes( context.scopes, 'users:read' )
|
|
|
|
if ( !args.id && !context.userId ) {
|
|
throw new UserInputError( 'You must provide an user id.' )
|
|
}
|
|
|
|
return await getUser( args.id || context.userId )
|
|
}
|
|
},
|
|
User: {
|
|
async email( parent, args, context, info ) {
|
|
// if it's me, go ahead
|
|
if ( context.userId === parent.id )
|
|
return parent.email
|
|
|
|
// otherwise check scopes
|
|
try {
|
|
await validateScopes( context.scopes, 'users:email' )
|
|
return parent.email
|
|
} catch ( err ) {
|
|
return null
|
|
}
|
|
},
|
|
async role( parent, args, context, info ) {
|
|
return await getUserRole( parent.id )
|
|
}
|
|
},
|
|
Mutation: {
|
|
async userEdit( parent, args, context, info ) {
|
|
await validateServerRole( context, 'server:user' )
|
|
await updateUser( context.userId, args.user )
|
|
return true
|
|
},
|
|
async userCreate( parent, args, context, info ) {
|
|
let setupComplete = await setupCheck( )
|
|
if ( setupComplete && process.env.STRATEGY_LOCAL !== 'true' )
|
|
throw new ApolloError( 'Registration method not available' )
|
|
|
|
let userId = await createUser( args.user )
|
|
let token = await createToken( userId, "Default Token", [ 'streams:read', 'streams:write' ] )
|
|
return token
|
|
|
|
}
|
|
}
|
|
} |