Files
speckle-server/modules/core/graph/resolvers/apitoken.js
T
2020-07-14 15:13:44 +01:00

34 lines
1.4 KiB
JavaScript

'use strict'
const appRoot = require( 'app-root-path' )
const { AuthorizationError, ApolloError } = require( 'apollo-server-express' )
const { createPersonalAccessToken, revokeToken, revokeTokenById, validateToken, getUserTokens } = require( '../../services/tokens' )
const { validateServerRole, validateScopes, authorizeResolver } = require( `${appRoot}/modules/shared` )
module.exports = {
Query: {},
User: {
async apiTokens( parent, args, context, info ) {
// TODO!
await validateServerRole( context, 'server:user' )
await validateScopes( context.scopes, 'tokens:read' )
if ( parent.id !== context.userId ) throw new AuthorizationError( 'You can only view your own tokens' )
let tokens = await getUserTokens( context.userId )
return tokens
}
},
Mutation: {
async apiTokenCreate( parent, args, context, info ) {
await validateServerRole( context, 'server:user' )
await validateScopes( context.scopes, 'tokens:write' )
return await createPersonalAccessToken( context.userId, args.name, args.scopes, args.lifespan )
},
async apiTokenRevoke( parent, args, context, info ) {
await validateServerRole( context, 'server:user' )
await validateScopes( context.scopes, 'tokens:write' )
await revokeToken( args.token.split( ' ' )[ 1 ], context.userId ) // let's not revoke other people's tokens
return true
}
}
}