mirror of
https://github.com/Unleash/unleash.git
synced 2025-08-04 13:48:56 +02:00
add splash-controller and cascade migration
This commit is contained in:
parent
d73293c576
commit
cc516618a1
76
src/lib/routes/admin-api/user-splash-controller.ts
Normal file
76
src/lib/routes/admin-api/user-splash-controller.ts
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
import { Response } from 'express';
|
||||||
|
|
||||||
|
import Controller from '../controller';
|
||||||
|
import { Logger } from '../../logger';
|
||||||
|
import { IUnleashConfig } from '../../types/option';
|
||||||
|
import { IUnleashServices } from '../../types/services';
|
||||||
|
import UserSplashService from '../../services/user-splash-service';
|
||||||
|
import { IAuthRequest } from '../unleash-types';
|
||||||
|
|
||||||
|
interface ISplashBody {
|
||||||
|
seen: boolean;
|
||||||
|
splashId: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
class UserSplashController extends Controller {
|
||||||
|
private logger: Logger;
|
||||||
|
private userSplashService: UserSplashService;
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
config: IUnleashConfig,
|
||||||
|
{ userSplashService }: Pick<IUnleashServices, 'userSplashService'>,
|
||||||
|
) {
|
||||||
|
super(config);
|
||||||
|
this.logger = config.getLogger('splash-controller.ts');
|
||||||
|
this.userSplashService = userSplashService;
|
||||||
|
|
||||||
|
this.post('/', this.recordSplash);
|
||||||
|
this.put('/:id', this.updateSplashSettings);
|
||||||
|
}
|
||||||
|
|
||||||
|
private async recordSplash(
|
||||||
|
req: IAuthRequest<any, any, ISplashBody, any>,
|
||||||
|
res: Response,
|
||||||
|
): Promise<void> {
|
||||||
|
const BAD_REQUEST = 400;
|
||||||
|
const { user } = req;
|
||||||
|
|
||||||
|
const { splashId } = req.body;
|
||||||
|
|
||||||
|
if (!splashId) {
|
||||||
|
res.status(BAD_REQUEST).json({
|
||||||
|
error: 'splashId must be present.',
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const splash = {
|
||||||
|
...req.body,
|
||||||
|
userId: user.id,
|
||||||
|
seen: req.body.seen || false,
|
||||||
|
};
|
||||||
|
|
||||||
|
const updated = await this.userSplashService.updateSplash(splash);
|
||||||
|
res.json(updated);
|
||||||
|
}
|
||||||
|
|
||||||
|
private async updateSplashSettings(
|
||||||
|
req: IAuthRequest<any, any, ISplashBody, any>,
|
||||||
|
res: Response,
|
||||||
|
): Promise<void> {
|
||||||
|
const { user } = req;
|
||||||
|
const { id } = req.params;
|
||||||
|
|
||||||
|
const splash = {
|
||||||
|
...req.body,
|
||||||
|
splashId: id,
|
||||||
|
userId: user.id,
|
||||||
|
seen: req.body.seen || false,
|
||||||
|
};
|
||||||
|
|
||||||
|
const updated = await this.userSplashService.updateSplash(splash);
|
||||||
|
res.json(updated);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = UserSplashController;
|
16
src/migrations/20211109123505-add-cascade-for-user-splash.js
Normal file
16
src/migrations/20211109123505-add-cascade-for-user-splash.js
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
exports.up = function (db, cb) {
|
||||||
|
db.runSql(
|
||||||
|
`
|
||||||
|
ALTER TABLE user_splash DROP CONSTRAINT user_splash_user_id_fkey;
|
||||||
|
ALTER TABLE user_splash
|
||||||
|
ADD CONSTRAINT user_splash_user_id_fkey
|
||||||
|
FOREIGN KEY (user_id)
|
||||||
|
REFERENCES users(id) ON DELETE CASCADE;
|
||||||
|
`,
|
||||||
|
cb,
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
exports.down = function (db, cb) {
|
||||||
|
db.runSql('', cb);
|
||||||
|
};
|
Loading…
Reference in New Issue
Block a user