diff --git a/extensions/authentication-jwt/src/__tests__/fixtures/controllers/user.controller.ts b/extensions/authentication-jwt/src/__tests__/fixtures/controllers/user.controller.ts index 235c9fb83fa9..2acaa699e690 100644 --- a/extensions/authentication-jwt/src/__tests__/fixtures/controllers/user.controller.ts +++ b/extensions/authentication-jwt/src/__tests__/fixtures/controllers/user.controller.ts @@ -6,12 +6,15 @@ import { authenticate, TokenService, - UserService, + UserService } from '@loopback/authentication'; import {inject} from '@loopback/core'; import {get, post, requestBody} from '@loopback/rest'; import {SecurityBindings, securityId, UserProfile} from '@loopback/security'; +import {genSalt, hash} from 'bcryptjs'; import {TokenServiceBindings, User, UserServiceBindings} from '../../../'; +import {model, property} from '../../../../../../packages/repository/src'; +import {UserRepository} from '../../../repositories'; import {Credentials} from '../../../services/user.service'; const CredentialsSchema = { @@ -29,6 +32,15 @@ const CredentialsSchema = { }, }; +@model() +export class NewUserRequest extends User { + @property({ + type: 'string', + required: true, + }) + password: string; +} + export const CredentialsRequestBody = { description: 'The input of login function', required: true, @@ -45,8 +57,43 @@ export class UserController { public userService: UserService, @inject(SecurityBindings.USER, {optional: true}) private user: UserProfile, + @inject(UserServiceBindings.USER_REPOSITORY) + public userRepository: UserRepository ) {} + @post('/signup', { + responses: { + '200': { + description: 'User', + content: { + 'application/json': { + schema: { + 'x-ts-type': User, + }, + }, + }, + }, + }, + }) + async signUp( + @requestBody({ + content: { + 'application/json': { + schema: CredentialsSchema, + }, + }, + }) + newUserRequest: NewUserRequest, + ): Promise { + const password = await hash(newUserRequest.password, await genSalt()); + delete newUserRequest.password; + var savedUser = await this.userRepository.create(newUserRequest); + + await this.userRepository.userCredentials(savedUser.id).create({password}); + + return savedUser; + } + @post('/users/login', { responses: { '200': {