import { UserAdminFlag } from '../../../../shared/models/users/user-flag.model'
import { UserRegister } from '../../../../shared/models/users/user-register.model'
import { MUser, MUserAccountDefault } from '@server/typings/models'
+import { Hooks } from '@server/lib/plugins/hooks'
const auditLogger = auditLoggerFactory('users')
usersRouter.post('/token',
loginRateLimiter,
token,
- success
+ tokenSuccess
)
// TODO: Once https://github.com/oauthjs/node-oauth2-server/pull/289 is merged, implement revoke token route
adminFlags: body.adminFlags || UserAdminFlag.NONE
}) as MUser
- const { user, account } = await createUserAccountAndChannelAndPlaylist({ userToCreate: userToCreate })
+ const { user, account, videoChannel } = await createUserAccountAndChannelAndPlaylist({ userToCreate: userToCreate })
auditLogger.create(getAuditIdFromRes(res), new UserAuditView(user.toFormattedJSON()))
logger.info('User %s with its channel and account created.', body.username)
+ Hooks.runAction('action:api.user.created', { body, user, account, videoChannel })
+
return res.json({
user: {
id: user.id,
emailVerified: CONFIG.SIGNUP.REQUIRES_EMAIL_VERIFICATION ? false : null
})
- const { user } = await createUserAccountAndChannelAndPlaylist({
+ const { user, account, videoChannel } = await createUserAccountAndChannelAndPlaylist({
userToCreate: userToCreate,
userDisplayName: body.displayName || undefined,
channelNames: body.channel
Notifier.Instance.notifyOnNewUserRegistration(user)
+ Hooks.runAction('action:api.user.registered', { body, user, account, videoChannel })
+
return res.type('json').status(204).end()
}
await changeUserBlock(res, user, false)
+ Hooks.runAction('action:api.user.unblocked', { user })
+
return res.status(204).end()
}
await changeUserBlock(res, user, true, reason)
+ Hooks.runAction('action:api.user.blocked', { user })
+
return res.status(204).end()
}
auditLogger.delete(getAuditIdFromRes(res), new UserAuditView(user.toFormattedJSON()))
+ Hooks.runAction('action:api.user.deleted', { user })
+
return res.sendStatus(204)
}
auditLogger.update(getAuditIdFromRes(res), new UserAuditView(user.toFormattedJSON()), oldUserAuditView)
+ Hooks.runAction('action:api.user.updated', { user })
+
// Don't need to send this update to followers, these attributes are not federated
return res.sendStatus(204)
return res.status(204).end()
}
-function success (req: express.Request, res: express.Response) {
- res.end()
+function tokenSuccess (req: express.Request) {
+ const username = req.body.username
+
+ Hooks.runAction('action:api.user.oauth2-got-token', { username, ip: req.ip })
}
async function changeUserBlock (res: express.Response, user: MUserAccountDefault, block: boolean, reason?: string) {