@kipicore/dbcore 1.1.465 → 1.1.467
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/db/psql/migrations/20260423113851-update_sr_number.js +22 -0
- package/dist/interfaces/advertisementInterface.d.ts +17 -5
- package/dist/interfaces/index.d.ts +1 -2
- package/dist/interfaces/index.js +1 -2
- package/dist/interfaces/permissionsInterface.d.ts +1 -0
- package/dist/models/mongodb/advertisementModel.d.ts +4 -0
- package/dist/models/mongodb/{advertisementNewModel.js → advertisementModel.js} +3 -3
- package/dist/models/mongodb/index.d.ts +1 -1
- package/dist/models/mongodb/index.js +3 -3
- package/dist/models/psql/index.d.ts +0 -1
- package/dist/models/psql/index.js +2 -4
- package/dist/models/psql/permissionsModel.d.ts +1 -0
- package/dist/models/psql/permissionsModel.js +3 -0
- package/dist/types/advertisementType.d.ts +2 -3
- package/dist/types/index.d.ts +1 -2
- package/dist/types/index.js +1 -2
- package/package.json +1 -1
- package/dist/db/psql/migrations/20251106103307-advertisement.js +0 -196
- package/dist/db/psql/migrations/20260421095714-add_mediaUrl_to_advertisement.d.ts +0 -2
- package/dist/db/psql/migrations/20260421095714-add_mediaUrl_to_advertisement.js +0 -22
- package/dist/interfaces/advertisementNewInterface.d.ts +0 -27
- package/dist/interfaces/advertisementNewInterface.js +0 -2
- package/dist/models/mongodb/advertisementNewModel.d.ts +0 -4
- package/dist/models/psql/advertisementModel.d.ts +0 -25
- package/dist/models/psql/advertisementModel.js +0 -112
- package/dist/types/advertisementNewType.d.ts +0 -2
- package/dist/types/advertisementNewType.js +0 -2
- /package/dist/db/psql/migrations/{20251106103307-advertisement.d.ts → 20260423113851-update_sr_number.d.ts} +0 -0
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
const up = async (queryInterface, Sequelize) => {
|
|
3
|
+
const table = await queryInterface.describeTable('permissions');
|
|
4
|
+
if (!table.sequence_number) {
|
|
5
|
+
await queryInterface.addColumn('permissions', 'sequence_number', {
|
|
6
|
+
type: Sequelize.INTEGER,
|
|
7
|
+
allowNull: true,
|
|
8
|
+
field: 'sequence_number',
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
};
|
|
12
|
+
const down = async (queryInterface) => {
|
|
13
|
+
const table = await queryInterface.describeTable('permissions');
|
|
14
|
+
// Remove only if column exists
|
|
15
|
+
if (table.sequence_number) {
|
|
16
|
+
await queryInterface.removeColumn('permissions', 'sequence_number');
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
module.exports = {
|
|
20
|
+
up,
|
|
21
|
+
down,
|
|
22
|
+
};
|
|
@@ -1,15 +1,27 @@
|
|
|
1
1
|
import { IDefaultAttributes } from './commonInterface';
|
|
2
2
|
import { COMMAN_STATUS } from '../constants/app';
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
import { Document } from 'mongoose';
|
|
4
|
+
export interface ICommonBannerAndSlimSchema {
|
|
5
|
+
time: number;
|
|
6
|
+
fileStorageId: string;
|
|
7
|
+
link?: string;
|
|
8
|
+
}
|
|
9
|
+
export interface ITimeDurationSchema {
|
|
6
10
|
startTime: Date;
|
|
11
|
+
endDate: Date;
|
|
12
|
+
}
|
|
13
|
+
export interface IAdvertisementModelAttributes extends IDefaultAttributes, Document {
|
|
14
|
+
id: string;
|
|
15
|
+
title: string;
|
|
7
16
|
appType: string;
|
|
8
17
|
userType: string;
|
|
9
18
|
frequency: number;
|
|
10
19
|
instituteId: string;
|
|
11
20
|
description: string;
|
|
12
|
-
fileStorageId: string;
|
|
13
21
|
status: COMMAN_STATUS;
|
|
14
|
-
|
|
22
|
+
banner?: ICommonBannerAndSlimSchema[];
|
|
23
|
+
slim?: ICommonBannerAndSlimSchema[];
|
|
24
|
+
startDate: Date;
|
|
25
|
+
endDate: Date;
|
|
26
|
+
duration: ITimeDurationSchema[];
|
|
15
27
|
}
|
|
@@ -129,7 +129,6 @@ export * from './canteenInterface';
|
|
|
129
129
|
export * from './campusInterface';
|
|
130
130
|
export * from './entityWiseCalendarInterface';
|
|
131
131
|
export * from './workOffDaysInterface';
|
|
132
|
-
export * from './advertisementInterface';
|
|
133
132
|
export * from './additionalDetailsInterface';
|
|
134
133
|
export * from './bDayWishInterface';
|
|
135
134
|
export * from './themeInterface';
|
|
@@ -191,5 +190,5 @@ export * from './permissionsInterface';
|
|
|
191
190
|
export * from './roleHasPermissionInterface';
|
|
192
191
|
export * from './userHasPermissionInterface';
|
|
193
192
|
export * from './roleManagementInterface';
|
|
194
|
-
export * from './advertisementNewInterface';
|
|
195
193
|
export * from './noticeboardInterface';
|
|
194
|
+
export * from './advertisementInterface';
|
package/dist/interfaces/index.js
CHANGED
|
@@ -145,7 +145,6 @@ __exportStar(require("./canteenInterface"), exports);
|
|
|
145
145
|
__exportStar(require("./campusInterface"), exports);
|
|
146
146
|
__exportStar(require("./entityWiseCalendarInterface"), exports);
|
|
147
147
|
__exportStar(require("./workOffDaysInterface"), exports);
|
|
148
|
-
__exportStar(require("./advertisementInterface"), exports);
|
|
149
148
|
__exportStar(require("./additionalDetailsInterface"), exports);
|
|
150
149
|
__exportStar(require("./bDayWishInterface"), exports);
|
|
151
150
|
__exportStar(require("./themeInterface"), exports);
|
|
@@ -207,5 +206,5 @@ __exportStar(require("./permissionsInterface"), exports);
|
|
|
207
206
|
__exportStar(require("./roleHasPermissionInterface"), exports);
|
|
208
207
|
__exportStar(require("./userHasPermissionInterface"), exports);
|
|
209
208
|
__exportStar(require("./roleManagementInterface"), exports);
|
|
210
|
-
__exportStar(require("./advertisementNewInterface"), exports);
|
|
211
209
|
__exportStar(require("./noticeboardInterface"), exports);
|
|
210
|
+
__exportStar(require("./advertisementInterface"), exports);
|
|
@@ -9,6 +9,7 @@ export interface IPermissionAttributes extends IDefaultAttributes {
|
|
|
9
9
|
code: string;
|
|
10
10
|
appType: APP_TYPE;
|
|
11
11
|
userTypes: USER_TYPES[];
|
|
12
|
+
sequenceNumber: number;
|
|
12
13
|
}
|
|
13
14
|
export interface IPermissionTree extends IPermissionAttributes {
|
|
14
15
|
features?: IPermissionTree[];
|
|
@@ -44,7 +44,7 @@ const TimeDurationSchema = new mongoose_1.Schema({
|
|
|
44
44
|
startTime: { type: Date, required: false },
|
|
45
45
|
endDate: { type: Date, required: false },
|
|
46
46
|
}, { _id: false });
|
|
47
|
-
const
|
|
47
|
+
const advertisementSchema = new mongoose_1.Schema({
|
|
48
48
|
title: {
|
|
49
49
|
type: String,
|
|
50
50
|
required: false,
|
|
@@ -109,5 +109,5 @@ const advertisementNewSchema = new mongoose_1.Schema({
|
|
|
109
109
|
timestamps: true,
|
|
110
110
|
versionKey: false,
|
|
111
111
|
});
|
|
112
|
-
const
|
|
113
|
-
exports.default =
|
|
112
|
+
const AdvertisementModel = mongoose_1.default.model('advertisements', advertisementSchema);
|
|
113
|
+
exports.default = AdvertisementModel;
|
|
@@ -66,4 +66,4 @@ export { default as CommunityGroupModel } from './communityGroupModel';
|
|
|
66
66
|
export { default as CommunityGroupMemberModel } from './communityGroupMemberModel';
|
|
67
67
|
export { default as CommunityMessageModel } from './communityMessageModel';
|
|
68
68
|
export { default as RoleHasPermissionModel } from './roleHasPermissionModel';
|
|
69
|
-
export { default as
|
|
69
|
+
export { default as AdvertisementModel } from './advertisementModel';
|
|
@@ -4,7 +4,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.PollSelectionModel = exports.CreatePollModel = exports.SheetFieldMappingModel = exports.FileUploadUserDetails = exports.CompetitionUsersModel = exports.CompetitionGroupModel = exports.CompetitionModel = exports.CampusCarnivalModel = exports.AppointmentHistoryModel = exports.AppointmentModel = exports.SeatingArrangementModel = exports.AssignFileModel = exports.ThemeModel = exports.BDayWishModel = exports.AdditionalDetailModel = exports.CanteenModel = exports.WalletTransactionModel = exports.VideoAnalystModel = exports.UserSchoolMetaModel = exports.UserInstituteMetaModel = exports.UserDetailsModel = exports.UniqueNumberCounterModel = exports.TaskManagementModel = exports.SubscriptionPlanModel = exports.SubjectIndexModel = exports.ReplaceTeacherModel = exports.PlannerModel = exports.PhotosGalleryModel = exports.JobApplyModel = exports.InvoiceModel = exports.InquiryModel = exports.InformationSupportModel = exports.HolidayModel = exports.GenerateIdCardModel = exports.FeedBackModel = exports.FeeReminderTypeModel = exports.ExamModel = exports.ExamHasAnswerSheetModel = exports.ExamGroupModel = exports.EventModel = exports.DashboardManagementModel = exports.DailyBookModel = exports.ColumnModel = exports.CertificatesManagementModel = exports.CertificatesHistoryModel = exports.CareerModel = exports.BlogModel = exports.AttendanceModel = exports.ApprovalRequestModel = exports.connectMongoDb = void 0;
|
|
7
|
-
exports.
|
|
7
|
+
exports.AdvertisementModel = exports.RoleHasPermissionModel = exports.CommunityMessageModel = exports.CommunityGroupMemberModel = exports.CommunityGroupModel = exports.OfferAndDiscountModel = exports.SubscriptionConfigurationModel = exports.ModulePriceModel = exports.PdcChequeConfigurationModel = exports.FinalMarkSheetModel = exports.MarkSheetConfigurationModel = exports.AppAnalyticsEventModel = exports.GrantAndDonationModel = exports.TicketRaiseModel = exports.EducationOfficerModel = exports.InstituteFeeModel = exports.SchoolFee1Model = exports.FeeConfigModel = exports.EventTemplatesModel = void 0;
|
|
8
8
|
const mongoose_1 = __importDefault(require("mongoose"));
|
|
9
9
|
const env_1 = require("../../configs/env");
|
|
10
10
|
const transformIdInQueryPlugin_1 = __importDefault(require("./plugin/transformIdInQueryPlugin"));
|
|
@@ -159,5 +159,5 @@ var communityMessageModel_1 = require("./communityMessageModel");
|
|
|
159
159
|
Object.defineProperty(exports, "CommunityMessageModel", { enumerable: true, get: function () { return __importDefault(communityMessageModel_1).default; } });
|
|
160
160
|
var roleHasPermissionModel_1 = require("./roleHasPermissionModel");
|
|
161
161
|
Object.defineProperty(exports, "RoleHasPermissionModel", { enumerable: true, get: function () { return __importDefault(roleHasPermissionModel_1).default; } });
|
|
162
|
-
var
|
|
163
|
-
Object.defineProperty(exports, "
|
|
162
|
+
var advertisementModel_1 = require("./advertisementModel");
|
|
163
|
+
Object.defineProperty(exports, "AdvertisementModel", { enumerable: true, get: function () { return __importDefault(advertisementModel_1).default; } });
|
|
@@ -98,7 +98,6 @@ export { default as LostFoundItemModel } from './lostFoundItemModel';
|
|
|
98
98
|
export { default as CampusModel } from './campusModel';
|
|
99
99
|
export { default as EntityWiseCalendarModel } from './entityWiseCalendarModel';
|
|
100
100
|
export { default as WorkOffDaysModel } from './workOffDaysModel';
|
|
101
|
-
export { default as AdvertisementModel } from './advertisementModel';
|
|
102
101
|
export { default as MaintenanceModel } from './maintenanceModel';
|
|
103
102
|
export { default as IncomeExpenseModel } from './incomeExpenseModel';
|
|
104
103
|
export { default as CloneListModel } from './cloneListModel';
|
|
@@ -4,8 +4,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.ProjectAssessmentOptionModel = exports.ProductModel = exports.PincodeModel = exports.PdcHistoryModel = exports.PdcChequeModel = exports.OfferModel = exports.ModuleModel = exports.ModuleFeatureModel = exports.MasterLeaveModel = exports.LectureModel = exports.LectureHistoryModel = exports.InventoryModel = exports.InventoryHistoryModel = exports.InstituteSubscriptionPlanModel = exports.InstituteModel = exports.InstituteEntityTypeModel = exports.InstituteEntityModel = exports.HomeWorkModel = exports.GreetingsModel = exports.FloorManagementModel = exports.FileStorageModel = exports.FeeReminderSettingModel = exports.FeeReminderModel = exports.FeatureActionModel = exports.FacilityModel = exports.EntityGroupModel = exports.DriverModel = exports.CourseModel = exports.CourseHasVisitorsModel = exports.CountryModel = exports.ContactFeedBackModel = exports.CoinPurchaseOfferModel = exports.CloudStorageModel = exports.ClassRoomModel = exports.CityModel = exports.CategoriesModel = exports.BookAssessmentDateModel = exports.BatchSubjectProjectAssessmentModel = exports.BatchSubjectBookAssessmentModel = exports.BatchModel = exports.BannerModel = exports.BankAccountDetailsModel = exports.AreaModel = exports.AnnouncementModel = exports.AccountHasReceiptDetailsModel = exports.AcademicCalendarModel = exports.SubCategoriesModel = exports.Sequelize = exports.db = exports.sequelize = void 0;
|
|
7
|
-
exports.
|
|
8
|
-
exports.NoticeboardModel = exports.UserPermissionModel = exports.RoleManagementModel = exports.PermissionModel = exports.DesignationModel = exports.AdditionalPayoutTypeModel = exports.VisitorBookModel = exports.PostalDispatchModel = exports.CallRegisterModel = exports.UserHasOfferAndDiscountModel = exports.UserAcceptedTermsAndCondition = exports.SubjectInternalMarkModel = exports.InternalMarkModel = exports.TermsAndConditionModel = exports.FeeType1Model = exports.StudentFeeTermsModel = exports.UserHasPenaltyModel = exports.PenaltyModel = exports.ClassRoomCollectionModel = exports.ClassRoomEventModel = exports.StudentFeeTypeCollectionModel = exports.SchoolFeeTermsModel = exports.StudentFeeHistoryModel = exports.StudentFeeCollectionModel = exports.UserDirectoryModel = exports.StudentLeaveRequestModel = exports.CloneListModel =
|
|
7
|
+
exports.IncomeExpenseModel = exports.MaintenanceModel = exports.WorkOffDaysModel = exports.EntityWiseCalendarModel = exports.CampusModel = exports.LostFoundItemModel = exports.WorkingShiftModel = exports.WorkingDayModel = exports.WalletModel = exports.WalletHistoryModel = exports.VendorManagementModel = exports.VehicleModel = exports.UserRequiredStepsModel = exports.UserProjectAssessmentOptionModel = exports.UserPayoutModel = exports.UserPayoutHistoryModel = exports.UserPayoutDetailsModel = exports.UserModel = exports.UserLeaveRequestModel = exports.UserHasSubjectFeeModel = exports.UserHasStorageModel = exports.UserHasRollNumberModel = exports.UserHasRoleModel = exports.UserHasParentModel = exports.UserHasOfferModel = exports.UserHasLeaveModel = exports.UserHasLeaveHistoryModel = exports.UserHasInventoryModel = exports.UserHasInventoryHistoryModel = exports.UserHasHomeWorkModel = exports.UserHasFileModel = exports.UserHasDeviceModel = exports.UserHasCourseModel = exports.UserHasBatchModel = exports.UserHasAnnouncementModel = exports.UserBookAssessmentModel = exports.TypeManagementModel = exports.TripModel = exports.TokenModel = exports.ToDoModel = exports.TestimonialModel = exports.SyllabusModel = exports.SubjectHasPayFeeHistoryModel = exports.SubjectHasFeeModel = exports.StateModel = exports.SlotModel = exports.SendNotificationModel = exports.SchoolOfferModel = exports.RulesRegulationModel = exports.RoleModel = void 0;
|
|
8
|
+
exports.NoticeboardModel = exports.UserPermissionModel = exports.RoleManagementModel = exports.PermissionModel = exports.DesignationModel = exports.AdditionalPayoutTypeModel = exports.VisitorBookModel = exports.PostalDispatchModel = exports.CallRegisterModel = exports.UserHasOfferAndDiscountModel = exports.UserAcceptedTermsAndCondition = exports.SubjectInternalMarkModel = exports.InternalMarkModel = exports.TermsAndConditionModel = exports.FeeType1Model = exports.StudentFeeTermsModel = exports.UserHasPenaltyModel = exports.PenaltyModel = exports.ClassRoomCollectionModel = exports.ClassRoomEventModel = exports.StudentFeeTypeCollectionModel = exports.SchoolFeeTermsModel = exports.StudentFeeHistoryModel = exports.StudentFeeCollectionModel = exports.UserDirectoryModel = exports.StudentLeaveRequestModel = exports.CloneListModel = void 0;
|
|
9
9
|
const sequelize_1 = require("sequelize");
|
|
10
10
|
Object.defineProperty(exports, "Sequelize", { enumerable: true, get: function () { return sequelize_1.Sequelize; } });
|
|
11
11
|
const postgresConfig = require('../../configs/postgresConfig');
|
|
@@ -290,8 +290,6 @@ var entityWiseCalendarModel_1 = require("./entityWiseCalendarModel");
|
|
|
290
290
|
Object.defineProperty(exports, "EntityWiseCalendarModel", { enumerable: true, get: function () { return __importDefault(entityWiseCalendarModel_1).default; } });
|
|
291
291
|
var workOffDaysModel_1 = require("./workOffDaysModel");
|
|
292
292
|
Object.defineProperty(exports, "WorkOffDaysModel", { enumerable: true, get: function () { return __importDefault(workOffDaysModel_1).default; } });
|
|
293
|
-
var advertisementModel_1 = require("./advertisementModel");
|
|
294
|
-
Object.defineProperty(exports, "AdvertisementModel", { enumerable: true, get: function () { return __importDefault(advertisementModel_1).default; } });
|
|
295
293
|
var maintenanceModel_1 = require("./maintenanceModel");
|
|
296
294
|
Object.defineProperty(exports, "MaintenanceModel", { enumerable: true, get: function () { return __importDefault(maintenanceModel_1).default; } });
|
|
297
295
|
var incomeExpenseModel_1 = require("./incomeExpenseModel");
|
|
@@ -1,3 +1,2 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
export type TAdvertisementCreationAttributes = Optional<IAdvertisementModelAttributes, 'id'>;
|
|
1
|
+
import { IAdvertisementModelAttributes } from "../interfaces/advertisementInterface";
|
|
2
|
+
export type TAdvertisementCreationAttributes = Omit<IAdvertisementModelAttributes, 'id'>;
|
package/dist/types/index.d.ts
CHANGED
|
@@ -121,7 +121,7 @@ export * from './canteenType';
|
|
|
121
121
|
export * from './campusType';
|
|
122
122
|
export * from './entityWiseCalendarType';
|
|
123
123
|
export * from './workOffDaysType';
|
|
124
|
-
export * from './
|
|
124
|
+
export * from './advertisementType';
|
|
125
125
|
export * from './bDayWishType';
|
|
126
126
|
export * from './themeType';
|
|
127
127
|
export * from './assignFileType';
|
|
@@ -182,5 +182,4 @@ export * from './permissionsType';
|
|
|
182
182
|
export * from './roleHasPermissionType';
|
|
183
183
|
export * from './userHasPermissionType';
|
|
184
184
|
export * from './roleManagementType';
|
|
185
|
-
export * from './advertisementType';
|
|
186
185
|
export * from './noticeboardType';
|
package/dist/types/index.js
CHANGED
|
@@ -137,7 +137,7 @@ __exportStar(require("./canteenType"), exports);
|
|
|
137
137
|
__exportStar(require("./campusType"), exports);
|
|
138
138
|
__exportStar(require("./entityWiseCalendarType"), exports);
|
|
139
139
|
__exportStar(require("./workOffDaysType"), exports);
|
|
140
|
-
__exportStar(require("./
|
|
140
|
+
__exportStar(require("./advertisementType"), exports);
|
|
141
141
|
__exportStar(require("./bDayWishType"), exports);
|
|
142
142
|
__exportStar(require("./themeType"), exports);
|
|
143
143
|
__exportStar(require("./assignFileType"), exports);
|
|
@@ -198,5 +198,4 @@ __exportStar(require("./permissionsType"), exports);
|
|
|
198
198
|
__exportStar(require("./roleHasPermissionType"), exports);
|
|
199
199
|
__exportStar(require("./userHasPermissionType"), exports);
|
|
200
200
|
__exportStar(require("./roleManagementType"), exports);
|
|
201
|
-
__exportStar(require("./advertisementType"), exports);
|
|
202
201
|
__exportStar(require("./noticeboardType"), exports);
|
package/package.json
CHANGED
|
@@ -1,196 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const up = async (queryInterface, Sequelize) => {
|
|
3
|
-
const tableName = 'advertisements';
|
|
4
|
-
const tableExists = await queryInterface
|
|
5
|
-
.describeTable(tableName)
|
|
6
|
-
.then(() => true)
|
|
7
|
-
.catch(() => false);
|
|
8
|
-
if (!tableExists) {
|
|
9
|
-
await queryInterface.createTable(tableName, {
|
|
10
|
-
id: {
|
|
11
|
-
type: Sequelize.UUID,
|
|
12
|
-
defaultValue: Sequelize.UUIDV4,
|
|
13
|
-
allowNull: false,
|
|
14
|
-
primaryKey: true,
|
|
15
|
-
},
|
|
16
|
-
status: {
|
|
17
|
-
type: Sequelize.STRING,
|
|
18
|
-
allowNull: true,
|
|
19
|
-
defaultValue: 'ACTIVE',
|
|
20
|
-
},
|
|
21
|
-
userType: {
|
|
22
|
-
type: Sequelize.STRING,
|
|
23
|
-
allowNull: true,
|
|
24
|
-
field: 'user_type',
|
|
25
|
-
},
|
|
26
|
-
frequency: {
|
|
27
|
-
type: Sequelize.INTEGER,
|
|
28
|
-
allowNull: true,
|
|
29
|
-
},
|
|
30
|
-
startTime: {
|
|
31
|
-
type: Sequelize.DATE,
|
|
32
|
-
allowNull: true,
|
|
33
|
-
field: 'start_time',
|
|
34
|
-
},
|
|
35
|
-
endTime: {
|
|
36
|
-
type: Sequelize.DATE,
|
|
37
|
-
allowNull: true,
|
|
38
|
-
field: 'end_time',
|
|
39
|
-
},
|
|
40
|
-
appType: {
|
|
41
|
-
type: Sequelize.STRING,
|
|
42
|
-
allowNull: true,
|
|
43
|
-
field: 'app_type',
|
|
44
|
-
},
|
|
45
|
-
description: {
|
|
46
|
-
type: Sequelize.STRING,
|
|
47
|
-
allowNull: true,
|
|
48
|
-
},
|
|
49
|
-
fileStorageId: {
|
|
50
|
-
type: Sequelize.STRING,
|
|
51
|
-
allowNull: true,
|
|
52
|
-
field: 'file_storage_id',
|
|
53
|
-
},
|
|
54
|
-
instituteId: {
|
|
55
|
-
type: Sequelize.UUID,
|
|
56
|
-
allowNull: true,
|
|
57
|
-
field: 'institute_id',
|
|
58
|
-
},
|
|
59
|
-
createdBy: {
|
|
60
|
-
type: Sequelize.UUID,
|
|
61
|
-
allowNull: true,
|
|
62
|
-
field: 'created_by',
|
|
63
|
-
},
|
|
64
|
-
updatedBy: {
|
|
65
|
-
type: Sequelize.UUID,
|
|
66
|
-
allowNull: true,
|
|
67
|
-
field: 'updated_by',
|
|
68
|
-
},
|
|
69
|
-
deletedBy: {
|
|
70
|
-
type: Sequelize.UUID,
|
|
71
|
-
allowNull: true,
|
|
72
|
-
field: 'deleted_by',
|
|
73
|
-
},
|
|
74
|
-
createdAt: {
|
|
75
|
-
type: Sequelize.DATE,
|
|
76
|
-
allowNull: true,
|
|
77
|
-
field: 'created_at',
|
|
78
|
-
},
|
|
79
|
-
updatedAt: {
|
|
80
|
-
type: Sequelize.DATE,
|
|
81
|
-
allowNull: true,
|
|
82
|
-
field: 'updated_at',
|
|
83
|
-
},
|
|
84
|
-
deletedAt: {
|
|
85
|
-
type: Sequelize.DATE,
|
|
86
|
-
allowNull: true,
|
|
87
|
-
field: 'deleted_at',
|
|
88
|
-
},
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
else {
|
|
92
|
-
const tableDefinition = await queryInterface.describeTable(tableName);
|
|
93
|
-
const columnsToAdd = {
|
|
94
|
-
id: {
|
|
95
|
-
type: Sequelize.UUID,
|
|
96
|
-
defaultValue: Sequelize.UUIDV4,
|
|
97
|
-
allowNull: false,
|
|
98
|
-
primaryKey: true,
|
|
99
|
-
},
|
|
100
|
-
status: {
|
|
101
|
-
type: Sequelize.STRING,
|
|
102
|
-
allowNull: true,
|
|
103
|
-
defaultValue: 'ACTIVE',
|
|
104
|
-
},
|
|
105
|
-
userType: {
|
|
106
|
-
type: Sequelize.STRING,
|
|
107
|
-
allowNull: true,
|
|
108
|
-
field: 'user_type',
|
|
109
|
-
},
|
|
110
|
-
frequency: {
|
|
111
|
-
type: Sequelize.INTEGER,
|
|
112
|
-
allowNull: true,
|
|
113
|
-
},
|
|
114
|
-
startTime: {
|
|
115
|
-
type: Sequelize.DATE,
|
|
116
|
-
allowNull: true,
|
|
117
|
-
field: 'start_time',
|
|
118
|
-
},
|
|
119
|
-
endTime: {
|
|
120
|
-
type: Sequelize.DATE,
|
|
121
|
-
allowNull: true,
|
|
122
|
-
field: 'end_time',
|
|
123
|
-
},
|
|
124
|
-
appType: {
|
|
125
|
-
type: Sequelize.STRING,
|
|
126
|
-
allowNull: true,
|
|
127
|
-
field: 'app_type',
|
|
128
|
-
},
|
|
129
|
-
description: {
|
|
130
|
-
type: Sequelize.STRING,
|
|
131
|
-
allowNull: true,
|
|
132
|
-
},
|
|
133
|
-
fileStorageId: {
|
|
134
|
-
type: Sequelize.STRING,
|
|
135
|
-
allowNull: true,
|
|
136
|
-
field: 'file_storage_id',
|
|
137
|
-
},
|
|
138
|
-
instituteId: {
|
|
139
|
-
type: Sequelize.UUID,
|
|
140
|
-
allowNull: true,
|
|
141
|
-
field: 'institute_id',
|
|
142
|
-
},
|
|
143
|
-
createdBy: {
|
|
144
|
-
type: Sequelize.UUID,
|
|
145
|
-
allowNull: true,
|
|
146
|
-
field: 'created_by',
|
|
147
|
-
},
|
|
148
|
-
updatedBy: {
|
|
149
|
-
type: Sequelize.UUID,
|
|
150
|
-
allowNull: true,
|
|
151
|
-
field: 'updated_by',
|
|
152
|
-
},
|
|
153
|
-
deletedBy: {
|
|
154
|
-
type: Sequelize.UUID,
|
|
155
|
-
allowNull: true,
|
|
156
|
-
field: 'deleted_by',
|
|
157
|
-
},
|
|
158
|
-
createdAt: {
|
|
159
|
-
type: Sequelize.DATE,
|
|
160
|
-
allowNull: true,
|
|
161
|
-
field: 'created_at',
|
|
162
|
-
},
|
|
163
|
-
updatedAt: {
|
|
164
|
-
type: Sequelize.DATE,
|
|
165
|
-
allowNull: true,
|
|
166
|
-
field: 'updated_at',
|
|
167
|
-
},
|
|
168
|
-
deletedAt: {
|
|
169
|
-
type: Sequelize.DATE,
|
|
170
|
-
allowNull: true,
|
|
171
|
-
field: 'deleted_at',
|
|
172
|
-
},
|
|
173
|
-
};
|
|
174
|
-
for (const column of Object.keys(columnsToAdd)) {
|
|
175
|
-
const columnToAdd = columnsToAdd[column];
|
|
176
|
-
const tableColumn = columnToAdd.field || column;
|
|
177
|
-
if (!tableDefinition[tableColumn]) {
|
|
178
|
-
await queryInterface.addColumn(tableName, tableColumn, columnToAdd);
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
};
|
|
183
|
-
const down = async (queryInterface) => {
|
|
184
|
-
const tableName = 'advertisements';
|
|
185
|
-
const tableExists = await queryInterface
|
|
186
|
-
.describeTable(tableName)
|
|
187
|
-
.then(() => true)
|
|
188
|
-
.catch(() => false);
|
|
189
|
-
if (tableExists) {
|
|
190
|
-
await queryInterface.dropTable(tableName);
|
|
191
|
-
}
|
|
192
|
-
};
|
|
193
|
-
module.exports = {
|
|
194
|
-
up,
|
|
195
|
-
down,
|
|
196
|
-
};
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
const up = async (queryInterface, Sequelize) => {
|
|
3
|
-
const table = await queryInterface.describeTable('advertisements');
|
|
4
|
-
if (!table.media_url) {
|
|
5
|
-
await queryInterface.addColumn('advertisements', 'media_url', {
|
|
6
|
-
type: Sequelize.STRING,
|
|
7
|
-
allowNull: true,
|
|
8
|
-
field: 'media_url',
|
|
9
|
-
});
|
|
10
|
-
}
|
|
11
|
-
};
|
|
12
|
-
const down = async (queryInterface) => {
|
|
13
|
-
const table = await queryInterface.describeTable('advertisements');
|
|
14
|
-
// Remove only if column exists
|
|
15
|
-
if (table.media_url) {
|
|
16
|
-
await queryInterface.removeColumn('advertisements', 'media_url');
|
|
17
|
-
}
|
|
18
|
-
};
|
|
19
|
-
module.exports = {
|
|
20
|
-
up,
|
|
21
|
-
down,
|
|
22
|
-
};
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { IDefaultAttributes } from './commonInterface';
|
|
2
|
-
import { COMMAN_STATUS } from '../constants/app';
|
|
3
|
-
import { Document } from 'mongoose';
|
|
4
|
-
export interface ICommonBannerAndSlimSchema {
|
|
5
|
-
time: number;
|
|
6
|
-
fileStorageId: string;
|
|
7
|
-
link?: string;
|
|
8
|
-
}
|
|
9
|
-
export interface ITimeDurationSchema {
|
|
10
|
-
startTime: Date;
|
|
11
|
-
endDate: Date;
|
|
12
|
-
}
|
|
13
|
-
export interface IAdvertisementNewModelAttributes extends IDefaultAttributes, Document {
|
|
14
|
-
id: string;
|
|
15
|
-
title: string;
|
|
16
|
-
appType: string;
|
|
17
|
-
userType: string;
|
|
18
|
-
frequency: number;
|
|
19
|
-
instituteId: string;
|
|
20
|
-
description: string;
|
|
21
|
-
status: COMMAN_STATUS;
|
|
22
|
-
banner?: ICommonBannerAndSlimSchema[];
|
|
23
|
-
slim?: ICommonBannerAndSlimSchema[];
|
|
24
|
-
startDate: Date;
|
|
25
|
-
endDate: Date;
|
|
26
|
-
duration: ITimeDurationSchema[];
|
|
27
|
-
}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { Model } from 'sequelize';
|
|
2
|
-
import { IAdvertisementModelAttributes } from '../../interfaces/advertisementInterface';
|
|
3
|
-
import { TAdvertisementCreationAttributes } from '../../types/advertisementType';
|
|
4
|
-
import { APP_TYPE, COMMAN_STATUS, USER_TYPES } from '../../constants';
|
|
5
|
-
declare class AdvertisementModel extends Model<IAdvertisementModelAttributes, TAdvertisementCreationAttributes> {
|
|
6
|
-
id: string;
|
|
7
|
-
endTime: Date;
|
|
8
|
-
startTime: Date;
|
|
9
|
-
frequency: number;
|
|
10
|
-
appType: APP_TYPE;
|
|
11
|
-
instituteId: string;
|
|
12
|
-
description: string;
|
|
13
|
-
userType: USER_TYPES;
|
|
14
|
-
fileStorageId: string;
|
|
15
|
-
status: COMMAN_STATUS;
|
|
16
|
-
mediaUrl?: string;
|
|
17
|
-
createdBy: string;
|
|
18
|
-
updatedBy: string;
|
|
19
|
-
deletedBy: string;
|
|
20
|
-
readonly createdAt: Date;
|
|
21
|
-
readonly updatedAt: Date;
|
|
22
|
-
readonly deletedAt: string;
|
|
23
|
-
static associate(models: any): void;
|
|
24
|
-
}
|
|
25
|
-
export default AdvertisementModel;
|
|
@@ -1,112 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const sequelize_1 = require("sequelize");
|
|
4
|
-
const constants_1 = require("../../constants");
|
|
5
|
-
const index_1 = require("./index");
|
|
6
|
-
class AdvertisementModel extends sequelize_1.Model {
|
|
7
|
-
static associate(models) {
|
|
8
|
-
const { UserModel, InstituteModel } = models;
|
|
9
|
-
AdvertisementModel.belongsTo(UserModel, {
|
|
10
|
-
foreignKey: {
|
|
11
|
-
name: 'createdBy',
|
|
12
|
-
allowNull: true,
|
|
13
|
-
field: 'created_by',
|
|
14
|
-
},
|
|
15
|
-
as: 'createdByUser',
|
|
16
|
-
});
|
|
17
|
-
AdvertisementModel.belongsTo(UserModel, {
|
|
18
|
-
foreignKey: {
|
|
19
|
-
name: 'updatedBy',
|
|
20
|
-
allowNull: true,
|
|
21
|
-
field: 'updated_by',
|
|
22
|
-
},
|
|
23
|
-
as: 'updatedByUser',
|
|
24
|
-
});
|
|
25
|
-
AdvertisementModel.belongsTo(UserModel, {
|
|
26
|
-
foreignKey: {
|
|
27
|
-
name: 'deletedBy',
|
|
28
|
-
allowNull: true,
|
|
29
|
-
field: 'deleted_by',
|
|
30
|
-
},
|
|
31
|
-
as: 'deletedByUser',
|
|
32
|
-
});
|
|
33
|
-
AdvertisementModel.belongsTo(InstituteModel, {
|
|
34
|
-
foreignKey: {
|
|
35
|
-
name: 'instituteId',
|
|
36
|
-
allowNull: true,
|
|
37
|
-
field: 'institute_id',
|
|
38
|
-
},
|
|
39
|
-
as: 'instituteAdvertisement',
|
|
40
|
-
});
|
|
41
|
-
InstituteModel.hasMany(AdvertisementModel, {
|
|
42
|
-
foreignKey: {
|
|
43
|
-
name: 'instituteId',
|
|
44
|
-
allowNull: true,
|
|
45
|
-
field: 'institute_id',
|
|
46
|
-
},
|
|
47
|
-
as: 'advertisementInstitute',
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
AdvertisementModel.init({
|
|
52
|
-
id: {
|
|
53
|
-
type: sequelize_1.DataTypes.UUID,
|
|
54
|
-
defaultValue: sequelize_1.DataTypes.UUIDV4,
|
|
55
|
-
allowNull: false,
|
|
56
|
-
primaryKey: true,
|
|
57
|
-
},
|
|
58
|
-
status: {
|
|
59
|
-
type: sequelize_1.DataTypes.STRING,
|
|
60
|
-
allowNull: true,
|
|
61
|
-
defaultValue: constants_1.COMMAN_STATUS.ACTIVE,
|
|
62
|
-
},
|
|
63
|
-
userType: {
|
|
64
|
-
type: sequelize_1.DataTypes.STRING,
|
|
65
|
-
allowNull: true,
|
|
66
|
-
field: 'user_type',
|
|
67
|
-
},
|
|
68
|
-
frequency: {
|
|
69
|
-
type: sequelize_1.DataTypes.INTEGER,
|
|
70
|
-
allowNull: true,
|
|
71
|
-
},
|
|
72
|
-
startTime: {
|
|
73
|
-
type: sequelize_1.DataTypes.DATE,
|
|
74
|
-
allowNull: true,
|
|
75
|
-
field: 'start_time',
|
|
76
|
-
},
|
|
77
|
-
endTime: {
|
|
78
|
-
type: sequelize_1.DataTypes.DATE,
|
|
79
|
-
allowNull: true,
|
|
80
|
-
field: 'end_time',
|
|
81
|
-
},
|
|
82
|
-
appType: {
|
|
83
|
-
type: sequelize_1.DataTypes.STRING,
|
|
84
|
-
allowNull: true,
|
|
85
|
-
field: 'app_type',
|
|
86
|
-
},
|
|
87
|
-
description: {
|
|
88
|
-
type: sequelize_1.DataTypes.STRING,
|
|
89
|
-
allowNull: true,
|
|
90
|
-
},
|
|
91
|
-
fileStorageId: {
|
|
92
|
-
type: sequelize_1.DataTypes.STRING,
|
|
93
|
-
allowNull: true,
|
|
94
|
-
field: 'file_storage_id',
|
|
95
|
-
},
|
|
96
|
-
instituteId: {
|
|
97
|
-
type: sequelize_1.DataTypes.UUID,
|
|
98
|
-
allowNull: true,
|
|
99
|
-
field: 'institute_id',
|
|
100
|
-
},
|
|
101
|
-
mediaUrl: {
|
|
102
|
-
type: sequelize_1.DataTypes.STRING,
|
|
103
|
-
allowNull: true,
|
|
104
|
-
field: 'media_url',
|
|
105
|
-
},
|
|
106
|
-
}, {
|
|
107
|
-
modelName: 'advertisement',
|
|
108
|
-
tableName: 'advertisements',
|
|
109
|
-
timestamps: true,
|
|
110
|
-
sequelize: index_1.sequelize,
|
|
111
|
-
});
|
|
112
|
-
exports.default = AdvertisementModel;
|
|
File without changes
|