@remnawave/backend-contract 0.2.0 → 0.2.1

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.
Files changed (41) hide show
  1. package/build/backend/api/controllers/auth.d.ts +2 -0
  2. package/build/backend/api/controllers/auth.d.ts.map +1 -1
  3. package/build/backend/api/controllers/auth.js +2 -0
  4. package/build/backend/api/routes.d.ts +2 -0
  5. package/build/backend/api/routes.d.ts.map +1 -1
  6. package/build/backend/api/routes.js +2 -0
  7. package/build/backend/commands/auth/get-status.command.d.ts +29 -0
  8. package/build/backend/commands/auth/get-status.command.d.ts.map +1 -0
  9. package/build/backend/commands/auth/get-status.command.js +16 -0
  10. package/build/backend/commands/auth/index.d.ts +2 -0
  11. package/build/backend/commands/auth/index.d.ts.map +1 -1
  12. package/build/backend/commands/auth/index.js +2 -0
  13. package/build/backend/commands/auth/register.command.d.ts +35 -0
  14. package/build/backend/commands/auth/register.command.d.ts.map +1 -0
  15. package/build/backend/commands/auth/register.command.js +22 -0
  16. package/build/backend/commands/users/create-user.command.d.ts +4 -4
  17. package/build/backend/commands/users/disable-user.command.ts.d.ts +2 -2
  18. package/build/backend/commands/users/enable-user.command.d.ts +2 -2
  19. package/build/backend/commands/users/get-all-users-v2.command.d.ts +3 -3
  20. package/build/backend/commands/users/get-user-by-email.command.d.ts +2 -2
  21. package/build/backend/commands/users/get-user-by-short-uuid.command.d.ts +2 -2
  22. package/build/backend/commands/users/get-user-by-subscription-uuid.command.d.ts +2 -2
  23. package/build/backend/commands/users/get-user-by-telegram-id.command.d.ts +2 -2
  24. package/build/backend/commands/users/get-user-by-username.command.d.ts +2 -2
  25. package/build/backend/commands/users/get-user-by-uuid.command.d.ts +2 -2
  26. package/build/backend/commands/users/reset-user-traffic.command.d.ts +2 -2
  27. package/build/backend/commands/users/revoke-user-subscription.command.d.ts +2 -2
  28. package/build/backend/commands/users/update-user.command.d.ts +4 -4
  29. package/build/backend/constants/errors/errors.d.ts +25 -0
  30. package/build/backend/constants/errors/errors.d.ts.map +1 -1
  31. package/build/backend/constants/errors/errors.js +17 -0
  32. package/build/backend/constants/roles/role.d.ts +1 -0
  33. package/build/backend/constants/roles/role.d.ts.map +1 -1
  34. package/build/backend/models/users.schema.d.ts +1 -1
  35. package/build/frontend/api/controllers/auth.js +2 -0
  36. package/build/frontend/api/routes.js +2 -0
  37. package/build/frontend/commands/auth/get-status.command.js +16 -0
  38. package/build/frontend/commands/auth/index.js +2 -0
  39. package/build/frontend/commands/auth/register.command.js +22 -0
  40. package/build/frontend/constants/errors/errors.js +17 -0
  41. package/package.json +1 -1
@@ -1,5 +1,7 @@
1
1
  export declare const AUTH_CONTROLLER: "auth";
2
2
  export declare const AUTH_ROUTES: {
3
3
  readonly LOGIN: "login";
4
+ readonly REGISTER: "register";
5
+ readonly GET_STATUS: "status";
4
6
  };
5
7
  //# sourceMappingURL=auth.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../../../api/controllers/auth.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,eAAe,EAAG,MAAe,CAAC;AAE/C,eAAO,MAAM,WAAW;;CAEd,CAAC"}
1
+ {"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../../../api/controllers/auth.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,eAAe,EAAG,MAAe,CAAC;AAE/C,eAAO,MAAM,WAAW;;;;CAId,CAAC"}
@@ -4,4 +4,6 @@ exports.AUTH_ROUTES = exports.AUTH_CONTROLLER = void 0;
4
4
  exports.AUTH_CONTROLLER = 'auth';
5
5
  exports.AUTH_ROUTES = {
6
6
  LOGIN: 'login',
7
+ REGISTER: 'register',
8
+ GET_STATUS: 'status',
7
9
  };
@@ -3,6 +3,8 @@ export declare const METRICS_ROOT: "/metrics";
3
3
  export declare const REST_API: {
4
4
  readonly AUTH: {
5
5
  readonly LOGIN: "/api/auth/login";
6
+ readonly REGISTER: "/api/auth/register";
7
+ readonly GET_STATUS: "/api/auth/status";
6
8
  };
7
9
  readonly API_TOKENS: {
8
10
  readonly CREATE: "/api/tokens/create";
@@ -1 +1 @@
1
- {"version":3,"file":"routes.d.ts","sourceRoot":"","sources":["../../../api/routes.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,IAAI,EAAG,MAAe,CAAC;AACpC,eAAO,MAAM,YAAY,EAAG,UAAmB,CAAC;AAEhD,eAAO,MAAM,QAAQ;;;;;;gCAME,MAAM;;;;;;;;gCASN,MAAM;;;iCAIL,MAAM;iCAEN,MAAM;iCAEN,MAAM;gCAEP,MAAM;;;;;;;;;;;;;;;;qCAiBD,MAAM;gDAEK,MAAM;6CAET,MAAM;8DAEW,MAAM;6CAEvB,MAAM;sCAEb,MAAM;qCAEP,MAAM;qCAEN,MAAM;;;4CAIC,MAAM;;;;kDAKA,MAAM;uCAEjB,MAAM;;;kCAIX,MAAM;uCAED,MAAM;;;;;;;;gCASb,MAAM;;;;;;;CAQnB,CAAC"}
1
+ {"version":3,"file":"routes.d.ts","sourceRoot":"","sources":["../../../api/routes.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,IAAI,EAAG,MAAe,CAAC;AACpC,eAAO,MAAM,YAAY,EAAG,UAAmB,CAAC;AAEhD,eAAO,MAAM,QAAQ;;;;;;;;gCAQE,MAAM;;;;;;;;gCASN,MAAM;;;iCAIL,MAAM;iCAEN,MAAM;iCAEN,MAAM;gCAEP,MAAM;;;;;;;;;;;;;;;;qCAiBD,MAAM;gDAEK,MAAM;6CAET,MAAM;8DAEW,MAAM;6CAEvB,MAAM;sCAEb,MAAM;qCAEP,MAAM;qCAEN,MAAM;;;4CAIC,MAAM;;;;kDAKA,MAAM;uCAEjB,MAAM;;;kCAIX,MAAM;uCAED,MAAM;;;;;;;;gCASb,MAAM;;;;;;;CAQnB,CAAC"}
@@ -40,6 +40,8 @@ exports.METRICS_ROOT = '/metrics';
40
40
  exports.REST_API = {
41
41
  AUTH: {
42
42
  LOGIN: `${exports.ROOT}/${CONTROLLERS.AUTH_CONTROLLER}/${CONTROLLERS.AUTH_ROUTES.LOGIN}`,
43
+ REGISTER: `${exports.ROOT}/${CONTROLLERS.AUTH_CONTROLLER}/${CONTROLLERS.AUTH_ROUTES.REGISTER}`,
44
+ GET_STATUS: `${exports.ROOT}/${CONTROLLERS.AUTH_CONTROLLER}/${CONTROLLERS.AUTH_ROUTES.GET_STATUS}`,
43
45
  },
44
46
  API_TOKENS: {
45
47
  CREATE: `${exports.ROOT}/${CONTROLLERS.API_TOKENS_CONTROLLER}/${CONTROLLERS.API_TOKENS_ROUTES.CREATE}`,
@@ -0,0 +1,29 @@
1
+ import { z } from 'zod';
2
+ export declare namespace GetStatusCommand {
3
+ const url: "/api/auth/status";
4
+ const TSQ_url: "/api/auth/status";
5
+ const ResponseSchema: z.ZodObject<{
6
+ response: z.ZodObject<{
7
+ isLoginAllowed: z.ZodBoolean;
8
+ isRegisterAllowed: z.ZodBoolean;
9
+ }, "strip", z.ZodTypeAny, {
10
+ isLoginAllowed: boolean;
11
+ isRegisterAllowed: boolean;
12
+ }, {
13
+ isLoginAllowed: boolean;
14
+ isRegisterAllowed: boolean;
15
+ }>;
16
+ }, "strip", z.ZodTypeAny, {
17
+ response: {
18
+ isLoginAllowed: boolean;
19
+ isRegisterAllowed: boolean;
20
+ };
21
+ }, {
22
+ response: {
23
+ isLoginAllowed: boolean;
24
+ isRegisterAllowed: boolean;
25
+ };
26
+ }>;
27
+ type Response = z.infer<typeof ResponseSchema>;
28
+ }
29
+ //# sourceMappingURL=get-status.command.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-status.command.d.ts","sourceRoot":"","sources":["../../../../commands/auth/get-status.command.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,yBAAiB,gBAAgB,CAAC;IACvB,MAAM,GAAG,oBAA2B,CAAC;IACrC,MAAM,OAAO,oBAAM,CAAC;IAEpB,MAAM,cAAc;;;;;;;;;;;;;;;;;;;;;MAKzB,CAAC;IAEH,KAAY,QAAQ,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,cAAc,CAAC,CAAC;CACzD"}
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GetStatusCommand = void 0;
4
+ const zod_1 = require("zod");
5
+ const api_1 = require("../../api");
6
+ var GetStatusCommand;
7
+ (function (GetStatusCommand) {
8
+ GetStatusCommand.url = api_1.REST_API.AUTH.GET_STATUS;
9
+ GetStatusCommand.TSQ_url = GetStatusCommand.url;
10
+ GetStatusCommand.ResponseSchema = zod_1.z.object({
11
+ response: zod_1.z.object({
12
+ isLoginAllowed: zod_1.z.boolean(),
13
+ isRegisterAllowed: zod_1.z.boolean(),
14
+ }),
15
+ });
16
+ })(GetStatusCommand || (exports.GetStatusCommand = GetStatusCommand = {}));
@@ -1,2 +1,4 @@
1
1
  export * from './login.command';
2
+ export * from './register.command';
3
+ export * from './get-status.command';
2
4
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../commands/auth/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../commands/auth/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,oBAAoB,CAAC;AACnC,cAAc,sBAAsB,CAAC"}
@@ -15,3 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./login.command"), exports);
18
+ __exportStar(require("./register.command"), exports);
19
+ __exportStar(require("./get-status.command"), exports);
@@ -0,0 +1,35 @@
1
+ import { z } from 'zod';
2
+ export declare namespace RegisterCommand {
3
+ const url: "/api/auth/register";
4
+ const TSQ_url: "/api/auth/register";
5
+ const RequestSchema: z.ZodObject<{
6
+ username: z.ZodString;
7
+ password: z.ZodString;
8
+ }, "strip", z.ZodTypeAny, {
9
+ username: string;
10
+ password: string;
11
+ }, {
12
+ username: string;
13
+ password: string;
14
+ }>;
15
+ type Request = z.infer<typeof RequestSchema>;
16
+ const ResponseSchema: z.ZodObject<{
17
+ response: z.ZodObject<{
18
+ accessToken: z.ZodString;
19
+ }, "strip", z.ZodTypeAny, {
20
+ accessToken: string;
21
+ }, {
22
+ accessToken: string;
23
+ }>;
24
+ }, "strip", z.ZodTypeAny, {
25
+ response: {
26
+ accessToken: string;
27
+ };
28
+ }, {
29
+ response: {
30
+ accessToken: string;
31
+ };
32
+ }>;
33
+ type Response = z.infer<typeof ResponseSchema>;
34
+ }
35
+ //# sourceMappingURL=register.command.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"register.command.d.ts","sourceRoot":"","sources":["../../../../commands/auth/register.command.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,yBAAiB,eAAe,CAAC;IACtB,MAAM,GAAG,sBAAyB,CAAC;IACnC,MAAM,OAAO,sBAAM,CAAC;IAEpB,MAAM,aAAa;;;;;;;;;MASxB,CAAC;IAEH,KAAY,OAAO,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,aAAa,CAAC,CAAC;IAE7C,MAAM,cAAc;;;;;;;;;;;;;;;;MAIzB,CAAC;IAEH,KAAY,QAAQ,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,cAAc,CAAC,CAAC;CACzD"}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RegisterCommand = void 0;
4
+ const zod_1 = require("zod");
5
+ const api_1 = require("../../api");
6
+ var RegisterCommand;
7
+ (function (RegisterCommand) {
8
+ RegisterCommand.url = api_1.REST_API.AUTH.REGISTER;
9
+ RegisterCommand.TSQ_url = RegisterCommand.url;
10
+ RegisterCommand.RequestSchema = zod_1.z.object({
11
+ username: zod_1.z.string(),
12
+ password: zod_1.z
13
+ .string()
14
+ .min(12, 'Password must contain at least 12 characters')
15
+ .regex(/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*?&])[A-Za-z\d@$!%*?&]/, 'Password must contain uppercase and lowercase letters, numbers and special characters'),
16
+ });
17
+ RegisterCommand.ResponseSchema = zod_1.z.object({
18
+ response: zod_1.z.object({
19
+ accessToken: zod_1.z.string(),
20
+ }),
21
+ });
22
+ })(RegisterCommand || (exports.RegisterCommand = RegisterCommand = {}));
@@ -31,8 +31,8 @@ export declare namespace CreateUserCommand {
31
31
  email: z.ZodOptional<z.ZodString>;
32
32
  activateAllInbounds: z.ZodOptional<z.ZodBoolean>;
33
33
  }, "strip", z.ZodTypeAny, {
34
- username: string;
35
34
  status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
35
+ username: string;
36
36
  trafficLimitStrategy: "MONTH" | "NO_RESET" | "DAY" | "WEEK";
37
37
  expireAt: Date;
38
38
  email?: string | undefined;
@@ -51,8 +51,8 @@ export declare namespace CreateUserCommand {
51
51
  }, {
52
52
  username: string;
53
53
  expireAt: string;
54
- email?: string | undefined;
55
54
  status?: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE" | undefined;
55
+ email?: string | undefined;
56
56
  createdAt?: string | undefined;
57
57
  trafficLimitBytes?: number | undefined;
58
58
  subscriptionUuid?: string | undefined;
@@ -129,10 +129,10 @@ export declare namespace CreateUserCommand {
129
129
  nodeName: string;
130
130
  }>>;
131
131
  }>, "strip", z.ZodTypeAny, {
132
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
132
133
  uuid: string;
133
134
  username: string;
134
135
  email: string | null;
135
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
136
136
  createdAt: Date;
137
137
  updatedAt: Date;
138
138
  trafficLimitBytes: number;
@@ -199,10 +199,10 @@ export declare namespace CreateUserCommand {
199
199
  }>;
200
200
  }, "strip", z.ZodTypeAny, {
201
201
  response: {
202
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
202
203
  uuid: string;
203
204
  username: string;
204
205
  email: string | null;
205
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
206
206
  createdAt: Date;
207
207
  updatedAt: Date;
208
208
  trafficLimitBytes: number;
@@ -71,10 +71,10 @@ export declare namespace DisableUserCommand {
71
71
  nodeName: string;
72
72
  }>>;
73
73
  }>, "strip", z.ZodTypeAny, {
74
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
74
75
  uuid: string;
75
76
  username: string;
76
77
  email: string | null;
77
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
78
78
  createdAt: Date;
79
79
  updatedAt: Date;
80
80
  trafficLimitBytes: number;
@@ -141,10 +141,10 @@ export declare namespace DisableUserCommand {
141
141
  }>;
142
142
  }, "strip", z.ZodTypeAny, {
143
143
  response: {
144
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
144
145
  uuid: string;
145
146
  username: string;
146
147
  email: string | null;
147
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
148
148
  createdAt: Date;
149
149
  updatedAt: Date;
150
150
  trafficLimitBytes: number;
@@ -71,10 +71,10 @@ export declare namespace EnableUserCommand {
71
71
  nodeName: string;
72
72
  }>>;
73
73
  }>, "strip", z.ZodTypeAny, {
74
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
74
75
  uuid: string;
75
76
  username: string;
76
77
  email: string | null;
77
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
78
78
  createdAt: Date;
79
79
  updatedAt: Date;
80
80
  trafficLimitBytes: number;
@@ -141,10 +141,10 @@ export declare namespace EnableUserCommand {
141
141
  }>;
142
142
  }, "strip", z.ZodTypeAny, {
143
143
  response: {
144
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
144
145
  uuid: string;
145
146
  username: string;
146
147
  email: string | null;
147
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
148
148
  createdAt: Date;
149
149
  updatedAt: Date;
150
150
  trafficLimitBytes: number;
@@ -117,10 +117,10 @@ export declare namespace GetAllUsersV2Command {
117
117
  nodeName: string;
118
118
  }>>;
119
119
  }>, "strip", z.ZodTypeAny, {
120
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
120
121
  uuid: string;
121
122
  username: string;
122
123
  email: string | null;
123
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
124
124
  createdAt: Date;
125
125
  updatedAt: Date;
126
126
  trafficLimitBytes: number;
@@ -188,10 +188,10 @@ export declare namespace GetAllUsersV2Command {
188
188
  total: z.ZodNumber;
189
189
  }, "strip", z.ZodTypeAny, {
190
190
  users: {
191
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
191
192
  uuid: string;
192
193
  username: string;
193
194
  email: string | null;
194
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
195
195
  createdAt: Date;
196
196
  updatedAt: Date;
197
197
  trafficLimitBytes: number;
@@ -264,10 +264,10 @@ export declare namespace GetAllUsersV2Command {
264
264
  }, "strip", z.ZodTypeAny, {
265
265
  response: {
266
266
  users: {
267
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
267
268
  uuid: string;
268
269
  username: string;
269
270
  email: string | null;
270
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
271
271
  createdAt: Date;
272
272
  updatedAt: Date;
273
273
  trafficLimitBytes: number;
@@ -71,10 +71,10 @@ export declare namespace GetUserByEmailCommand {
71
71
  nodeName: string;
72
72
  }>>;
73
73
  }>, "strip", z.ZodTypeAny, {
74
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
74
75
  uuid: string;
75
76
  username: string;
76
77
  email: string | null;
77
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
78
78
  createdAt: Date;
79
79
  updatedAt: Date;
80
80
  trafficLimitBytes: number;
@@ -141,10 +141,10 @@ export declare namespace GetUserByEmailCommand {
141
141
  }>, "many">;
142
142
  }, "strip", z.ZodTypeAny, {
143
143
  response: {
144
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
144
145
  uuid: string;
145
146
  username: string;
146
147
  email: string | null;
147
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
148
148
  createdAt: Date;
149
149
  updatedAt: Date;
150
150
  trafficLimitBytes: number;
@@ -71,10 +71,10 @@ export declare namespace GetUserByShortUuidCommand {
71
71
  nodeName: string;
72
72
  }>>;
73
73
  }>, "strip", z.ZodTypeAny, {
74
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
74
75
  uuid: string;
75
76
  username: string;
76
77
  email: string | null;
77
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
78
78
  createdAt: Date;
79
79
  updatedAt: Date;
80
80
  trafficLimitBytes: number;
@@ -141,10 +141,10 @@ export declare namespace GetUserByShortUuidCommand {
141
141
  }>;
142
142
  }, "strip", z.ZodTypeAny, {
143
143
  response: {
144
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
144
145
  uuid: string;
145
146
  username: string;
146
147
  email: string | null;
147
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
148
148
  createdAt: Date;
149
149
  updatedAt: Date;
150
150
  trafficLimitBytes: number;
@@ -71,10 +71,10 @@ export declare namespace GetUserBySubscriptionUuidCommand {
71
71
  nodeName: string;
72
72
  }>>;
73
73
  }>, "strip", z.ZodTypeAny, {
74
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
74
75
  uuid: string;
75
76
  username: string;
76
77
  email: string | null;
77
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
78
78
  createdAt: Date;
79
79
  updatedAt: Date;
80
80
  trafficLimitBytes: number;
@@ -141,10 +141,10 @@ export declare namespace GetUserBySubscriptionUuidCommand {
141
141
  }>;
142
142
  }, "strip", z.ZodTypeAny, {
143
143
  response: {
144
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
144
145
  uuid: string;
145
146
  username: string;
146
147
  email: string | null;
147
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
148
148
  createdAt: Date;
149
149
  updatedAt: Date;
150
150
  trafficLimitBytes: number;
@@ -71,10 +71,10 @@ export declare namespace GetUserByTelegramIdCommand {
71
71
  nodeName: string;
72
72
  }>>;
73
73
  }>, "strip", z.ZodTypeAny, {
74
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
74
75
  uuid: string;
75
76
  username: string;
76
77
  email: string | null;
77
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
78
78
  createdAt: Date;
79
79
  updatedAt: Date;
80
80
  trafficLimitBytes: number;
@@ -141,10 +141,10 @@ export declare namespace GetUserByTelegramIdCommand {
141
141
  }>, "many">;
142
142
  }, "strip", z.ZodTypeAny, {
143
143
  response: {
144
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
144
145
  uuid: string;
145
146
  username: string;
146
147
  email: string | null;
147
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
148
148
  createdAt: Date;
149
149
  updatedAt: Date;
150
150
  trafficLimitBytes: number;
@@ -71,10 +71,10 @@ export declare namespace GetUserByUsernameCommand {
71
71
  nodeName: string;
72
72
  }>>;
73
73
  }>, "strip", z.ZodTypeAny, {
74
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
74
75
  uuid: string;
75
76
  username: string;
76
77
  email: string | null;
77
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
78
78
  createdAt: Date;
79
79
  updatedAt: Date;
80
80
  trafficLimitBytes: number;
@@ -141,10 +141,10 @@ export declare namespace GetUserByUsernameCommand {
141
141
  }>;
142
142
  }, "strip", z.ZodTypeAny, {
143
143
  response: {
144
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
144
145
  uuid: string;
145
146
  username: string;
146
147
  email: string | null;
147
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
148
148
  createdAt: Date;
149
149
  updatedAt: Date;
150
150
  trafficLimitBytes: number;
@@ -71,10 +71,10 @@ export declare namespace GetUserByUuidCommand {
71
71
  nodeName: string;
72
72
  }>>;
73
73
  }>, "strip", z.ZodTypeAny, {
74
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
74
75
  uuid: string;
75
76
  username: string;
76
77
  email: string | null;
77
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
78
78
  createdAt: Date;
79
79
  updatedAt: Date;
80
80
  trafficLimitBytes: number;
@@ -141,10 +141,10 @@ export declare namespace GetUserByUuidCommand {
141
141
  }>;
142
142
  }, "strip", z.ZodTypeAny, {
143
143
  response: {
144
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
144
145
  uuid: string;
145
146
  username: string;
146
147
  email: string | null;
147
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
148
148
  createdAt: Date;
149
149
  updatedAt: Date;
150
150
  trafficLimitBytes: number;
@@ -71,10 +71,10 @@ export declare namespace ResetUserTrafficCommand {
71
71
  nodeName: string;
72
72
  }>>;
73
73
  }>, "strip", z.ZodTypeAny, {
74
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
74
75
  uuid: string;
75
76
  username: string;
76
77
  email: string | null;
77
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
78
78
  createdAt: Date;
79
79
  updatedAt: Date;
80
80
  trafficLimitBytes: number;
@@ -141,10 +141,10 @@ export declare namespace ResetUserTrafficCommand {
141
141
  }>;
142
142
  }, "strip", z.ZodTypeAny, {
143
143
  response: {
144
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
144
145
  uuid: string;
145
146
  username: string;
146
147
  email: string | null;
147
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
148
148
  createdAt: Date;
149
149
  updatedAt: Date;
150
150
  trafficLimitBytes: number;
@@ -71,10 +71,10 @@ export declare namespace RevokeUserSubscriptionCommand {
71
71
  nodeName: string;
72
72
  }>>;
73
73
  }>, "strip", z.ZodTypeAny, {
74
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
74
75
  uuid: string;
75
76
  username: string;
76
77
  email: string | null;
77
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
78
78
  createdAt: Date;
79
79
  updatedAt: Date;
80
80
  trafficLimitBytes: number;
@@ -141,10 +141,10 @@ export declare namespace RevokeUserSubscriptionCommand {
141
141
  }>;
142
142
  }, "strip", z.ZodTypeAny, {
143
143
  response: {
144
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
144
145
  uuid: string;
145
146
  username: string;
146
147
  email: string | null;
147
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
148
148
  createdAt: Date;
149
149
  updatedAt: Date;
150
150
  trafficLimitBytes: number;
@@ -70,8 +70,8 @@ export declare namespace UpdateUserCommand {
70
70
  email: z.ZodOptional<z.ZodString>;
71
71
  }>, "strip", z.ZodTypeAny, {
72
72
  uuid: string;
73
- email?: string | undefined;
74
73
  status?: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE" | undefined;
74
+ email?: string | undefined;
75
75
  trafficLimitBytes?: number | undefined;
76
76
  description?: string | undefined;
77
77
  trafficLimitStrategy?: "MONTH" | "NO_RESET" | "DAY" | "WEEK" | undefined;
@@ -80,8 +80,8 @@ export declare namespace UpdateUserCommand {
80
80
  activeUserInbounds?: string[] | undefined;
81
81
  }, {
82
82
  uuid: string;
83
- email?: string | undefined;
84
83
  status?: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE" | undefined;
84
+ email?: string | undefined;
85
85
  trafficLimitBytes?: number | undefined;
86
86
  description?: string | undefined;
87
87
  trafficLimitStrategy?: "MONTH" | "NO_RESET" | "DAY" | "WEEK" | undefined;
@@ -151,10 +151,10 @@ export declare namespace UpdateUserCommand {
151
151
  nodeName: string;
152
152
  }>>;
153
153
  }>, "strip", z.ZodTypeAny, {
154
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
154
155
  uuid: string;
155
156
  username: string;
156
157
  email: string | null;
157
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
158
158
  createdAt: Date;
159
159
  updatedAt: Date;
160
160
  trafficLimitBytes: number;
@@ -221,10 +221,10 @@ export declare namespace UpdateUserCommand {
221
221
  }>;
222
222
  }, "strip", z.ZodTypeAny, {
223
223
  response: {
224
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
224
225
  uuid: string;
225
226
  username: string;
226
227
  email: string | null;
227
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
228
228
  createdAt: Date;
229
229
  updatedAt: Date;
230
230
  trafficLimitBytes: number;
@@ -339,5 +339,30 @@ export declare const ERRORS: {
339
339
  readonly message: "User with specified params not found";
340
340
  readonly httpCode: 404;
341
341
  };
342
+ readonly UPDATE_EXCEEDED_TRAFFIC_USERS_ERROR: {
343
+ readonly code: "A064";
344
+ readonly message: "Update exceeded traffic users error";
345
+ readonly httpCode: 500;
346
+ };
347
+ readonly ADMIN_NOT_FOUND: {
348
+ readonly code: "A065";
349
+ readonly message: "Admin not found";
350
+ readonly httpCode: 404;
351
+ };
352
+ readonly CREATE_ADMIN_ERROR: {
353
+ readonly code: "A066";
354
+ readonly message: "Create admin error";
355
+ readonly httpCode: 500;
356
+ };
357
+ readonly GET_AUTH_STATUS_ERROR: {
358
+ readonly code: "A067";
359
+ readonly message: "Get auth status error";
360
+ readonly httpCode: 500;
361
+ };
362
+ readonly FORBIDDEN: {
363
+ readonly code: "A068";
364
+ readonly message: "Forbidden";
365
+ readonly httpCode: 403;
366
+ };
342
367
  };
343
368
  //# sourceMappingURL=errors.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../../constants/errors/errors.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAwJY,MAAM;;;;;;;;;;wCAUN,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCA4IN,MAAM;;;;;;;;;;;;;;;;CAgB3B,CAAC"}
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../../constants/errors/errors.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAwJY,MAAM;;;;;;;;;;wCAUN,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCA4IN,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAiC3B,CAAC"}
@@ -318,4 +318,21 @@ exports.ERRORS = {
318
318
  message: 'User with specified params not found',
319
319
  httpCode: 404,
320
320
  },
321
+ UPDATE_EXCEEDED_TRAFFIC_USERS_ERROR: {
322
+ code: 'A064',
323
+ message: 'Update exceeded traffic users error',
324
+ httpCode: 500,
325
+ },
326
+ ADMIN_NOT_FOUND: {
327
+ code: 'A065',
328
+ message: 'Admin not found',
329
+ httpCode: 404,
330
+ },
331
+ CREATE_ADMIN_ERROR: {
332
+ code: 'A066',
333
+ message: 'Create admin error',
334
+ httpCode: 500,
335
+ },
336
+ GET_AUTH_STATUS_ERROR: { code: 'A067', message: 'Get auth status error', httpCode: 500 },
337
+ FORBIDDEN: { code: 'A068', message: 'Forbidden', httpCode: 403 },
321
338
  };
@@ -4,4 +4,5 @@ export declare const ROLE: {
4
4
  };
5
5
  export type TRole = typeof ROLE;
6
6
  export type TRolesKeys = (typeof ROLE)[keyof typeof ROLE];
7
+ export type TRoleTypes = [keyof typeof ROLE][number];
7
8
  //# sourceMappingURL=role.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"role.d.ts","sourceRoot":"","sources":["../../../../constants/roles/role.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,IAAI;;;CAGP,CAAC;AAEX,MAAM,MAAM,KAAK,GAAG,OAAO,IAAI,CAAC;AAChC,MAAM,MAAM,UAAU,GAAG,CAAC,OAAO,IAAI,CAAC,CAAC,MAAM,OAAO,IAAI,CAAC,CAAC"}
1
+ {"version":3,"file":"role.d.ts","sourceRoot":"","sources":["../../../../constants/roles/role.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,IAAI;;;CAGP,CAAC;AAEX,MAAM,MAAM,KAAK,GAAG,OAAO,IAAI,CAAC;AAChC,MAAM,MAAM,UAAU,GAAG,CAAC,OAAO,IAAI,CAAC,CAAC,MAAM,OAAO,IAAI,CAAC,CAAC;AAC1D,MAAM,MAAM,UAAU,GAAG,CAAC,MAAM,OAAO,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC"}
@@ -47,10 +47,10 @@ export declare const UsersSchema: z.ZodObject<{
47
47
  tag: string;
48
48
  }>, "many">;
49
49
  }, "strip", z.ZodTypeAny, {
50
+ status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
50
51
  uuid: string;
51
52
  username: string;
52
53
  email: string | null;
53
- status: "DISABLED" | "LIMITED" | "EXPIRED" | "ACTIVE";
54
54
  createdAt: Date;
55
55
  updatedAt: Date;
56
56
  trafficLimitBytes: number;
@@ -4,4 +4,6 @@ exports.AUTH_ROUTES = exports.AUTH_CONTROLLER = void 0;
4
4
  exports.AUTH_CONTROLLER = 'auth';
5
5
  exports.AUTH_ROUTES = {
6
6
  LOGIN: 'login',
7
+ REGISTER: 'register',
8
+ GET_STATUS: 'status',
7
9
  };
@@ -40,6 +40,8 @@ exports.METRICS_ROOT = '/metrics';
40
40
  exports.REST_API = {
41
41
  AUTH: {
42
42
  LOGIN: `${exports.ROOT}/${CONTROLLERS.AUTH_CONTROLLER}/${CONTROLLERS.AUTH_ROUTES.LOGIN}`,
43
+ REGISTER: `${exports.ROOT}/${CONTROLLERS.AUTH_CONTROLLER}/${CONTROLLERS.AUTH_ROUTES.REGISTER}`,
44
+ GET_STATUS: `${exports.ROOT}/${CONTROLLERS.AUTH_CONTROLLER}/${CONTROLLERS.AUTH_ROUTES.GET_STATUS}`,
43
45
  },
44
46
  API_TOKENS: {
45
47
  CREATE: `${exports.ROOT}/${CONTROLLERS.API_TOKENS_CONTROLLER}/${CONTROLLERS.API_TOKENS_ROUTES.CREATE}`,
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GetStatusCommand = void 0;
4
+ const zod_1 = require("zod");
5
+ const api_1 = require("../../api");
6
+ var GetStatusCommand;
7
+ (function (GetStatusCommand) {
8
+ GetStatusCommand.url = api_1.REST_API.AUTH.GET_STATUS;
9
+ GetStatusCommand.TSQ_url = GetStatusCommand.url;
10
+ GetStatusCommand.ResponseSchema = zod_1.z.object({
11
+ response: zod_1.z.object({
12
+ isLoginAllowed: zod_1.z.boolean(),
13
+ isRegisterAllowed: zod_1.z.boolean(),
14
+ }),
15
+ });
16
+ })(GetStatusCommand || (exports.GetStatusCommand = GetStatusCommand = {}));
@@ -15,3 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./login.command"), exports);
18
+ __exportStar(require("./register.command"), exports);
19
+ __exportStar(require("./get-status.command"), exports);
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RegisterCommand = void 0;
4
+ const zod_1 = require("zod");
5
+ const api_1 = require("../../api");
6
+ var RegisterCommand;
7
+ (function (RegisterCommand) {
8
+ RegisterCommand.url = api_1.REST_API.AUTH.REGISTER;
9
+ RegisterCommand.TSQ_url = RegisterCommand.url;
10
+ RegisterCommand.RequestSchema = zod_1.z.object({
11
+ username: zod_1.z.string(),
12
+ password: zod_1.z
13
+ .string()
14
+ .min(12, 'Password must contain at least 12 characters')
15
+ .regex(/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*?&])[A-Za-z\d@$!%*?&]/, 'Password must contain uppercase and lowercase letters, numbers and special characters'),
16
+ });
17
+ RegisterCommand.ResponseSchema = zod_1.z.object({
18
+ response: zod_1.z.object({
19
+ accessToken: zod_1.z.string(),
20
+ }),
21
+ });
22
+ })(RegisterCommand || (exports.RegisterCommand = RegisterCommand = {}));
@@ -318,4 +318,21 @@ exports.ERRORS = {
318
318
  message: 'User with specified params not found',
319
319
  httpCode: 404,
320
320
  },
321
+ UPDATE_EXCEEDED_TRAFFIC_USERS_ERROR: {
322
+ code: 'A064',
323
+ message: 'Update exceeded traffic users error',
324
+ httpCode: 500,
325
+ },
326
+ ADMIN_NOT_FOUND: {
327
+ code: 'A065',
328
+ message: 'Admin not found',
329
+ httpCode: 404,
330
+ },
331
+ CREATE_ADMIN_ERROR: {
332
+ code: 'A066',
333
+ message: 'Create admin error',
334
+ httpCode: 500,
335
+ },
336
+ GET_AUTH_STATUS_ERROR: { code: 'A067', message: 'Get auth status error', httpCode: 500 },
337
+ FORBIDDEN: { code: 'A068', message: 'Forbidden', httpCode: 403 },
321
338
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@remnawave/backend-contract",
3
- "version": "0.2.0",
3
+ "version": "0.2.1",
4
4
  "public": true,
5
5
  "license": "AGPL-3.0-only",
6
6
  "description": "A contract library for Remnawave Backend. It can be used in backend and frontend.",