tethys.backend/app/models/role.ts

99 lines
3.0 KiB
TypeScript
Raw Permalink Normal View History

2024-03-14 19:25:27 +00:00
import { column, SnakeCaseNamingStrategy, manyToMany, beforeCreate, beforeUpdate } from '@adonisjs/lucid/orm';
import BaseModel from './base_model.js';
2023-03-03 15:54:28 +00:00
import { DateTime } from 'luxon';
// import moment from 'moment';
import dayjs from 'dayjs';
import User from './user.js';
import Permission from '#models/permission';
2024-03-14 19:25:27 +00:00
import type { ManyToMany } from "@adonisjs/lucid/types/relations";
2023-03-03 15:54:28 +00:00
export default class Role extends BaseModel {
public static namingStrategy = new SnakeCaseNamingStrategy();
public static primaryKey = 'id';
public static table = 'roles';
public static selfAssignPrimaryKey = false;
2023-03-03 15:54:28 +00:00
@column({
isPrimary: true,
})
public id: number;
2023-03-03 15:54:28 +00:00
@column({})
public display_name: string;
2023-03-03 15:54:28 +00:00
@column({})
public name: string;
2023-03-03 15:54:28 +00:00
@column({})
public description: string;
2023-03-03 15:54:28 +00:00
@column.dateTime({
serialize: (value: Date | null) => {
// return value ? moment(value).format('MMMM Do YYYY, HH:mm:ss') : value;
return value ? dayjs(value).format('MMMM D YYYY HH:mm a') : value;
},
2023-03-03 15:54:28 +00:00
autoCreate: true,
})
public created_at: DateTime;
2023-03-03 15:54:28 +00:00
@column.dateTime({
serialize: (value: Date | null) => {
return value ? dayjs(value).format('MMMM D YYYY HH:mm a') : value;
},
2023-03-03 15:54:28 +00:00
autoCreate: true,
autoUpdate: true,
})
public updated_at: DateTime;
2023-03-03 15:54:28 +00:00
@beforeCreate()
2023-03-03 15:54:28 +00:00
@beforeUpdate()
2024-03-14 19:25:27 +00:00
public static async resetDate(role: Role) {
role.created_at = this.formatDateTime(role.created_at);
role.updated_at = this.formatDateTime(role.updated_at);
}
2023-03-03 15:54:28 +00:00
// public static boot() {
// super.boot();
2023-03-03 15:54:28 +00:00
// this.before('create', async (_modelInstance) => {
// _modelInstance.created_at = this.formatDateTime(_modelInstance.created_at);
// _modelInstance.updated_at = this.formatDateTime(_modelInstance.updated_at);
// });
// this.before('update', async (_modelInstance) => {
// _modelInstance.created_at = this.formatDateTime(_modelInstance.created_at);
// _modelInstance.updated_at = this.formatDateTime(_modelInstance.updated_at);
// });
// }
2023-03-03 15:54:28 +00:00
2024-03-14 19:25:27 +00:00
private static formatDateTime(datetime: any) {
let value = new Date(datetime);
return datetime
? value.getFullYear() +
'-' +
(value.getMonth() + 1) +
'-' +
value.getDate() +
' ' +
value.getHours() +
':' +
value.getMinutes() +
':' +
value.getSeconds()
: datetime;
}
2023-03-03 15:54:28 +00:00
@manyToMany(() => User, {
pivotForeignKey: 'role_id',
pivotRelatedForeignKey: 'account_id',
pivotTable: 'link_accounts_roles',
})
public users: ManyToMany<typeof User>;
2023-03-03 15:54:28 +00:00
@manyToMany(() => Permission, {
pivotForeignKey: 'role_id',
pivotRelatedForeignKey: 'permission_id',
pivotTable: 'role_has_permissions',
})
public permissions: ManyToMany<typeof Permission>;
2023-03-03 15:54:28 +00:00
}