@armi-wave/common 1.23.0 → 1.23.2

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
@@ -2,13 +2,14 @@ import User from './models/User';
2
2
  import Post from './models/Post';
3
3
  import Comment from './models/Comment';
4
4
  import Reply from './models/Reply';
5
+ import Follow from './models/Follow';
5
6
  import BadRequestError from './errors/bad-request-error';
6
7
  import DatabaseConnectionError from './errors/database-connection-error';
7
8
  import CustomError from './errors/custom-error';
8
9
  import NotAuthorizedError from './errors/not-authorized-error';
9
10
  import NotFoundError from './errors/not-found-error';
10
11
  import RequestValidationError from './errors/request-validation-error';
11
- export { User, Post, Comment, Reply };
12
+ export { User, Post, Comment, Reply, Follow };
12
13
  export { BadRequestError, DatabaseConnectionError, CustomError, NotAuthorizedError, NotFoundError, RequestValidationError, };
13
14
  export * from './middlewares/current-user';
14
15
  export * from './middlewares/error-handler';
package/build/index.js CHANGED
@@ -17,7 +17,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
17
17
  return (mod && mod.__esModule) ? mod : { "default": mod };
18
18
  };
19
19
  Object.defineProperty(exports, "__esModule", { value: true });
20
- exports.upload = exports.ensureBucketExists = exports.minioClient = exports.RequestValidationError = exports.NotFoundError = exports.NotAuthorizedError = exports.CustomError = exports.DatabaseConnectionError = exports.BadRequestError = exports.Reply = exports.Comment = exports.Post = exports.User = void 0;
20
+ exports.upload = exports.ensureBucketExists = exports.minioClient = exports.RequestValidationError = exports.NotFoundError = exports.NotAuthorizedError = exports.CustomError = exports.DatabaseConnectionError = exports.BadRequestError = exports.Follow = exports.Reply = exports.Comment = exports.Post = exports.User = void 0;
21
21
  const User_1 = __importDefault(require("./models/User"));
22
22
  exports.User = User_1.default;
23
23
  const Post_1 = __importDefault(require("./models/Post"));
@@ -26,6 +26,8 @@ const Comment_1 = __importDefault(require("./models/Comment"));
26
26
  exports.Comment = Comment_1.default;
27
27
  const Reply_1 = __importDefault(require("./models/Reply"));
28
28
  exports.Reply = Reply_1.default;
29
+ const Follow_1 = __importDefault(require("./models/Follow"));
30
+ exports.Follow = Follow_1.default;
29
31
  const bad_request_error_1 = __importDefault(require("./errors/bad-request-error"));
30
32
  exports.BadRequestError = bad_request_error_1.default;
31
33
  const database_connection_error_1 = __importDefault(require("./errors/database-connection-error"));
@@ -1,24 +1,10 @@
1
- import mongoose from 'mongoose';
2
- interface FollowAttributes {
3
- userId: string;
4
- followers: Record<string, {
5
- followedAt: Date;
6
- }>;
7
- following: Record<string, {
8
- followedAt: Date;
9
- }>;
1
+ import mongoose, { Document, Model } from 'mongoose';
2
+ interface Follow extends Document {
3
+ follower: mongoose.Types.ObjectId;
4
+ following: mongoose.Types.ObjectId;
5
+ createdAt: Date;
10
6
  }
11
- interface FollowModel extends mongoose.Model<FollowDocument> {
12
- build(attrs: FollowAttributes): FollowDocument;
13
- }
14
- interface FollowDocument extends mongoose.Document {
15
- userId: string;
16
- followers: Record<string, {
17
- followedAt: Date;
18
- }>;
19
- following: Record<string, {
20
- followedAt: Date;
21
- }>;
7
+ interface FollowModel extends Model<Follow> {
22
8
  }
23
9
  declare const Follow: FollowModel;
24
10
  export default Follow;
@@ -1,25 +1,54 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
5
35
  Object.defineProperty(exports, "__esModule", { value: true });
6
- const mongoose_1 = __importDefault(require("mongoose"));
7
- const followSchema = new mongoose_1.default.Schema({
8
- userId: { type: String, required: true },
9
- followers: {
10
- type: Map,
11
- of: {
12
- followedAt: { type: Date, required: true },
13
- },
14
- default: {},
36
+ const mongoose_1 = __importStar(require("mongoose"));
37
+ // Define the schema
38
+ const followSchema = new mongoose_1.Schema({
39
+ follower: {
40
+ type: mongoose_1.Schema.Types.ObjectId,
41
+ ref: 'User',
42
+ required: true,
43
+ index: true,
15
44
  },
16
45
  following: {
17
- type: Map,
18
- of: {
19
- followedAt: { type: Date, required: true },
20
- },
21
- default: {},
46
+ type: mongoose_1.Schema.Types.ObjectId,
47
+ ref: 'User',
48
+ required: true,
49
+ index: true,
22
50
  },
51
+ createdAt: { type: Date, default: Date.now },
23
52
  }, {
24
53
  toJSON: {
25
54
  transform(doc, ret) {
@@ -29,8 +58,8 @@ const followSchema = new mongoose_1.default.Schema({
29
58
  },
30
59
  },
31
60
  });
32
- followSchema.statics.build = (attrs) => {
33
- return new Follow(attrs);
34
- };
61
+ // Ensure a user cannot follow the same person multiple times
62
+ followSchema.index({ follower: 1, following: 1 }, { unique: true });
63
+ // Create and export the model
35
64
  const Follow = mongoose_1.default.model('Follow', followSchema);
36
65
  exports.default = Follow;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@armi-wave/common",
3
- "version": "1.23.0",
3
+ "version": "1.23.2",
4
4
  "description": "",
5
5
  "main": "./build/index.js",
6
6
  "types": "./build/index.d.ts",