@duvdu-v1/duvdu 1.1.146 → 1.1.148

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/build/index.d.ts CHANGED
@@ -69,6 +69,7 @@ export * from './models/all-contracts.model';
69
69
  export * from './models/producer_contracts.model';
70
70
  export * from './models/rental.model';
71
71
  export * from './models/Review.model';
72
+ export * from './models/projectViews.model';
72
73
  export * from './services/category.service';
73
74
  export * from './services/projectView.service';
74
75
  export * from './types/notification.type';
package/build/index.js CHANGED
@@ -87,6 +87,7 @@ __exportStar(require("./models/all-contracts.model"), exports);
87
87
  __exportStar(require("./models/producer_contracts.model"), exports);
88
88
  __exportStar(require("./models/rental.model"), exports);
89
89
  __exportStar(require("./models/Review.model"), exports);
90
+ __exportStar(require("./models/projectViews.model"), exports);
90
91
  __exportStar(require("./services/category.service"), exports);
91
92
  __exportStar(require("./services/projectView.service"), exports);
92
93
  __exportStar(require("./types/notification.type"), exports);
@@ -52,26 +52,36 @@ const isauthenticated = (req, res, next) => __awaiter(void 0, void 0, void 0, fu
52
52
  en: `Forbidden: User is blocked ${req.loggedUser.isBlocked.reason}`,
53
53
  ar: ` ممنوع: المستخدم محظور ${req.loggedUser.isBlocked.reason}`,
54
54
  }, req.lang));
55
+ next();
55
56
  }
56
57
  catch (error) {
57
- // return res.status(423).json({ message: 'access token expired' });
58
- const user = yield User_model_1.Users.findOne({ token: req.session.refresh });
59
- if (!user)
60
- return res.status(423).json({ message: 'refresh token expired' });
61
- const role = yield Role_model_1.Roles.findById(user.role);
62
- if (!role)
63
- return res.status(423).json({ message: 'invalid role' });
64
- const accessToken = (0, exports.generateAccessToken)({
65
- id: user.id,
66
- isVerified: user.isVerified,
67
- isBlocked: user.isBlocked,
68
- role: { key: role.key, permissions: role.permissions },
69
- });
70
- req.session.access = accessToken;
71
- req.session.refresh = user.token;
72
- next();
58
+ try {
59
+ const payload = (0, jsonwebtoken_1.verify)(req.session.refresh, process.env.JWT_KEY);
60
+ const user = yield User_model_1.Users.findById(payload.id);
61
+ if (!user)
62
+ return res.status(423).json({ message: 'token expired' });
63
+ if (user.isBlocked.value)
64
+ return next(new unauthorized_error_1.UnauthorizedError({
65
+ en: `Forbidden: User is blocked ${req.loggedUser.isBlocked.reason}`,
66
+ ar: ` ممنوع: المستخدم محظور ${req.loggedUser.isBlocked.reason}`,
67
+ }, req.lang));
68
+ const role = yield Role_model_1.Roles.findById(user.role);
69
+ if (!role)
70
+ return res.status(423).json({ message: 'invalid role' });
71
+ const accessToken = (0, exports.generateAccessToken)({
72
+ id: user.id,
73
+ isVerified: user.isVerified,
74
+ isBlocked: user.isBlocked,
75
+ role: { key: role.key, permissions: role.permissions },
76
+ });
77
+ req.session.access = accessToken;
78
+ req.loggedUser = (0, jsonwebtoken_1.verify)(accessToken, process.env.JWT_KEY);
79
+ next();
80
+ }
81
+ catch (error) {
82
+ return res.status(423).json({ message: 'token expired' });
83
+ }
73
84
  }
74
- next();
75
85
  });
76
86
  exports.isauthenticated = isauthenticated;
77
87
  const generateAccessToken = (payload) => jsonwebtoken_1.default.sign(payload, process.env.JWT_KEY, {
@@ -25,7 +25,7 @@ const userSchema = new mongoose_1.Schema({
25
25
  password: String,
26
26
  verificationCode: { code: String, expireAt: Date, reason: { type: String, default: null } },
27
27
  isVerified: { type: Boolean, default: false },
28
- token: String,
28
+ refreshTokens: { token: { type: String, default: null }, fingerprint: { type: String, default: null }, clientType: { type: String, default: null } },
29
29
  profileImage: { type: String, default: 'defaults/profile.jpg' },
30
30
  coverImage: { type: String, default: null },
31
31
  location: { lat: { type: Number, default: null }, lng: { type: Number, default: null } },
@@ -0,0 +1,36 @@
1
+ /// <reference types="mongoose/types/document" />
2
+ /// <reference types="mongoose/types/aggregate" />
3
+ /// <reference types="mongoose/types/callback" />
4
+ /// <reference types="mongoose/types/collection" />
5
+ /// <reference types="mongoose/types/connection" />
6
+ /// <reference types="mongoose/types/cursor" />
7
+ /// <reference types="mongoose/types/error" />
8
+ /// <reference types="mongoose/types/expressions" />
9
+ /// <reference types="mongoose/types/helpers" />
10
+ /// <reference types="mongoose/types/middlewares" />
11
+ /// <reference types="mongoose/types/indexes" />
12
+ /// <reference types="mongoose/types/models" />
13
+ /// <reference types="mongoose/types/mongooseoptions" />
14
+ /// <reference types="mongoose/types/pipelinestage" />
15
+ /// <reference types="mongoose/types/populate" />
16
+ /// <reference types="mongoose/types/query" />
17
+ /// <reference types="mongoose/types/schemaoptions" />
18
+ /// <reference types="mongoose/types/schematypes" />
19
+ /// <reference types="mongoose/types/session" />
20
+ /// <reference types="mongoose/types/types" />
21
+ /// <reference types="mongoose/types/utility" />
22
+ /// <reference types="mongoose/types/validation" />
23
+ /// <reference types="mongoose/types/virtuals" />
24
+ /// <reference types="mongoose/types/inferschematype" />
25
+ import { Types } from 'mongoose';
26
+ interface IProjectView {
27
+ user: Types.ObjectId;
28
+ project: Types.ObjectId;
29
+ ref: string;
30
+ count: number;
31
+ date: Date;
32
+ }
33
+ export declare const ProjectView: import("mongoose").Model<IProjectView, {}, {}, {}, import("mongoose").Document<unknown, {}, IProjectView> & IProjectView & {
34
+ _id: Types.ObjectId;
35
+ }, any>;
36
+ export {};
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ProjectView = void 0;
4
+ const mongoose_1 = require("mongoose");
5
+ const model_names_1 = require("../types/model-names");
6
+ var RefModels;
7
+ (function (RefModels) {
8
+ RefModels["copyright"] = "portfolio-post";
9
+ RefModels["studio"] = "studio-booking";
10
+ })(RefModels || (RefModels = {}));
11
+ const projectViewSchema = new mongoose_1.Schema({
12
+ user: { type: mongoose_1.Schema.Types.ObjectId, ref: model_names_1.MODELS.user },
13
+ project: { type: mongoose_1.Schema.Types.ObjectId, refPath: 'ref' },
14
+ ref: { type: String, enum: RefModels },
15
+ count: { type: Number, default: 1 },
16
+ date: { type: Date, default: Date.now }
17
+ }, { timestamps: true, collection: model_names_1.MODELS.projectsViews });
18
+ projectViewSchema.index({ project: 1, ref: 1, date: 1 }, { unique: true });
19
+ exports.ProjectView = (0, mongoose_1.model)(model_names_1.MODELS.projectsViews, projectViewSchema);
@@ -1,29 +1 @@
1
- /// <reference types="mongoose/types/document" />
2
- /// <reference types="mongoose/types/aggregate" />
3
- /// <reference types="mongoose/types/callback" />
4
- /// <reference types="mongoose/types/collection" />
5
- /// <reference types="mongoose/types/connection" />
6
- /// <reference types="mongoose/types/cursor" />
7
- /// <reference types="mongoose/types/error" />
8
- /// <reference types="mongoose/types/expressions" />
9
- /// <reference types="mongoose/types/helpers" />
10
- /// <reference types="mongoose/types/middlewares" />
11
- /// <reference types="mongoose/types/indexes" />
12
- /// <reference types="mongoose/types/models" />
13
- /// <reference types="mongoose/types/mongooseoptions" />
14
- /// <reference types="mongoose/types/pipelinestage" />
15
- /// <reference types="mongoose/types/populate" />
16
- /// <reference types="mongoose/types/query" />
17
- /// <reference types="mongoose/types/schemaoptions" />
18
- /// <reference types="mongoose/types/schematypes" />
19
- /// <reference types="mongoose/types/session" />
20
- /// <reference types="mongoose/types/types" />
21
- /// <reference types="mongoose/types/utility" />
22
- /// <reference types="mongoose/types/validation" />
23
- /// <reference types="mongoose/types/virtuals" />
24
- /// <reference types="mongoose/types/inferschematype" />
25
- import { Document } from 'mongoose';
26
- import { Iuser } from '../types/User';
27
- type UserDocument = Document & Iuser;
28
- export declare const incrementProjectsView: (userId: string) => Promise<UserDocument>;
29
- export {};
1
+ export declare const incrementProjectsView: (userId: string, projectId: string, lang: string) => Promise<void>;
@@ -10,16 +10,26 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
10
10
  };
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.incrementProjectsView = void 0;
13
+ const notfound_error_1 = require("../errors/notfound-error");
14
+ const allProjects_model_1 = require("../models/allProjects.model");
15
+ const projectViews_model_1 = require("../models/projectViews.model");
13
16
  const User_model_1 = require("../models/User.model");
14
- const incrementProjectsView = (userId) => __awaiter(void 0, void 0, void 0, function* () {
17
+ const incrementProjectsView = (userId, projectId, lang) => __awaiter(void 0, void 0, void 0, function* () {
15
18
  try {
16
19
  const user = yield User_model_1.Users.findById(userId);
17
- if (!user) {
18
- throw new Error('User not found');
19
- }
20
+ const project = yield allProjects_model_1.Project.findOne({ project: projectId });
21
+ if (!user)
22
+ throw new notfound_error_1.NotFound({ en: 'user not found', ar: 'لم يتم العثور على المستخدم' }, lang);
20
23
  user.projectsView += 1;
21
24
  yield user.save();
22
- return user;
25
+ if (!project)
26
+ throw new notfound_error_1.NotFound({ en: 'project not found', ar: 'لم يتم العثور على المشروع' }, lang);
27
+ const today = new Date();
28
+ today.setHours(0, 0, 0, 0);
29
+ const update = yield projectViews_model_1.ProjectView.updateOne({ user: userId, project: project._id, date: today }, { $inc: { count: 1 }, $setOnInsert: { ref: project.cycle, date: today } }, { upsert: true });
30
+ if (!update.upsertedId) {
31
+ yield projectViews_model_1.ProjectView.updateOne({ user: userId, project: project._id, date: today }, { $inc: { count: 1 } });
32
+ }
23
33
  }
24
34
  catch (error) {
25
35
  console.error('Error incrementing projectsView:', error);
@@ -53,7 +53,11 @@ export interface Iuser {
53
53
  reason?: VerificationReason;
54
54
  };
55
55
  isVerified: boolean;
56
- token?: string;
56
+ refreshTokens?: {
57
+ fingerprint: string;
58
+ clientType: string;
59
+ token: string;
60
+ };
57
61
  profileImage?: string;
58
62
  coverImage?: string;
59
63
  location?: {
@@ -28,5 +28,6 @@ export declare enum MODELS {
28
28
  allContracts = "all_contracts",
29
29
  contractReports = "contract_reports",
30
30
  projectReview = "project_reviews",
31
- contractReview = "contract_review"
31
+ contractReview = "contract_review",
32
+ projectsViews = "projects_views"
32
33
  }
@@ -33,4 +33,5 @@ var MODELS;
33
33
  MODELS["contractReports"] = "contract_reports";
34
34
  MODELS["projectReview"] = "project_reviews";
35
35
  MODELS["contractReview"] = "contract_review";
36
+ MODELS["projectsViews"] = "projects_views";
36
37
  })(MODELS || (exports.MODELS = MODELS = {}));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@duvdu-v1/duvdu",
3
- "version": "1.1.146",
3
+ "version": "1.1.148",
4
4
  "main": "./build/index.js",
5
5
  "types": "./build/index.d.ts",
6
6
  "files": [