|
3 | 3 | import { DataTypes, QueryInterface } from 'sequelize' |
4 | 4 |
|
5 | 5 | /** @type {import('sequelize-cli').Migration} */ |
6 | | -module.exports = { |
7 | | - async up(queryInterface: QueryInterface, Sequelize: typeof DataTypes) { |
8 | | - await queryInterface.createTable('user', { |
9 | | - id: { |
10 | | - allowNull: false, |
11 | | - primaryKey: true, |
12 | | - type: Sequelize.UUID, |
13 | | - defaultValue: Sequelize.UUIDV4, |
| 6 | +export async function up(queryInterface: QueryInterface, Sequelize: typeof DataTypes) { |
| 7 | + await queryInterface.createTable('user', { |
| 8 | + id: { |
| 9 | + allowNull: false, |
| 10 | + primaryKey: true, |
| 11 | + type: Sequelize.UUID, |
| 12 | + defaultValue: Sequelize.UUIDV4, |
| 13 | + }, |
| 14 | + created_at: { |
| 15 | + allowNull: false, |
| 16 | + type: Sequelize.DATE, |
| 17 | + }, |
| 18 | + updated_at: { |
| 19 | + allowNull: false, |
| 20 | + type: Sequelize.DATE, |
| 21 | + }, |
| 22 | + deleted_at: { |
| 23 | + type: Sequelize.DATE, |
| 24 | + }, |
| 25 | + fullname: { |
| 26 | + allowNull: false, |
| 27 | + type: Sequelize.STRING, |
| 28 | + }, |
| 29 | + email: { |
| 30 | + allowNull: false, |
| 31 | + type: Sequelize.STRING, |
| 32 | + }, |
| 33 | + password: { |
| 34 | + allowNull: false, |
| 35 | + type: Sequelize.STRING, |
| 36 | + }, |
| 37 | + phone: { |
| 38 | + type: Sequelize.STRING('20'), |
| 39 | + }, |
| 40 | + token_verify: { |
| 41 | + type: Sequelize.TEXT, |
| 42 | + }, |
| 43 | + address: { |
| 44 | + type: Sequelize.TEXT, |
| 45 | + }, |
| 46 | + is_active: { |
| 47 | + allowNull: false, |
| 48 | + defaultValue: false, |
| 49 | + type: Sequelize.BOOLEAN, |
| 50 | + }, |
| 51 | + is_blocked: { |
| 52 | + allowNull: false, |
| 53 | + defaultValue: false, |
| 54 | + type: Sequelize.BOOLEAN, |
| 55 | + }, |
| 56 | + role_id: { |
| 57 | + allowNull: false, |
| 58 | + type: Sequelize.UUID, |
| 59 | + defaultValue: Sequelize.UUIDV4, |
| 60 | + references: { |
| 61 | + model: 'role', |
| 62 | + key: 'id', |
14 | 63 | }, |
15 | | - created_at: { |
16 | | - allowNull: false, |
17 | | - type: Sequelize.DATE, |
| 64 | + }, |
| 65 | + upload_id: { |
| 66 | + allowNull: true, |
| 67 | + type: Sequelize.UUID, |
| 68 | + defaultValue: Sequelize.UUIDV4, |
| 69 | + references: { |
| 70 | + model: 'upload', |
| 71 | + key: 'id', |
18 | 72 | }, |
19 | | - updated_at: { |
20 | | - allowNull: false, |
21 | | - type: Sequelize.DATE, |
22 | | - }, |
23 | | - deleted_at: { |
24 | | - type: Sequelize.DATE, |
25 | | - }, |
26 | | - fullname: { |
27 | | - allowNull: false, |
28 | | - type: Sequelize.STRING, |
29 | | - }, |
30 | | - email: { |
31 | | - allowNull: false, |
32 | | - type: Sequelize.STRING, |
33 | | - }, |
34 | | - password: { |
35 | | - allowNull: false, |
36 | | - type: Sequelize.STRING, |
37 | | - }, |
38 | | - phone: { |
39 | | - type: Sequelize.STRING('20'), |
40 | | - }, |
41 | | - token_verify: { |
42 | | - type: Sequelize.TEXT, |
43 | | - }, |
44 | | - address: { |
45 | | - type: Sequelize.TEXT, |
46 | | - }, |
47 | | - is_active: { |
48 | | - allowNull: false, |
49 | | - defaultValue: false, |
50 | | - type: Sequelize.BOOLEAN, |
51 | | - }, |
52 | | - is_blocked: { |
53 | | - allowNull: false, |
54 | | - defaultValue: false, |
55 | | - type: Sequelize.BOOLEAN, |
56 | | - }, |
57 | | - role_id: { |
58 | | - allowNull: false, |
59 | | - type: Sequelize.UUID, |
60 | | - defaultValue: Sequelize.UUIDV4, |
61 | | - references: { |
62 | | - model: 'role', |
63 | | - key: 'id', |
64 | | - }, |
65 | | - }, |
66 | | - upload_id: { |
67 | | - allowNull: true, |
68 | | - type: Sequelize.UUID, |
69 | | - defaultValue: Sequelize.UUIDV4, |
70 | | - references: { |
71 | | - model: 'upload', |
72 | | - key: 'id', |
73 | | - }, |
74 | | - }, |
75 | | - }) |
| 73 | + }, |
| 74 | + }) |
76 | 75 |
|
77 | | - await queryInterface.addConstraint('user', { |
78 | | - type: 'unique', |
79 | | - fields: ['email'], |
80 | | - name: 'UNIQUE_USERS_EMAIL', |
81 | | - }) |
82 | | - }, |
| 76 | + await queryInterface.addConstraint('user', { |
| 77 | + type: 'unique', |
| 78 | + fields: ['email'], |
| 79 | + name: 'UNIQUE_USERS_EMAIL', |
| 80 | + }) |
| 81 | +} |
83 | 82 |
|
84 | | - async down(queryInterface: QueryInterface, Sequelize: typeof DataTypes) { |
85 | | - await queryInterface.dropTable('user') |
86 | | - }, |
| 83 | +export async function down(queryInterface: QueryInterface, Sequelize: typeof DataTypes) { |
| 84 | + await queryInterface.dropTable('user') |
87 | 85 | } |
0 commit comments