@skroz/profile-api 1.0.11 → 1.0.12

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.
@@ -0,0 +1,10 @@
1
+ declare class SendTokenInput {
2
+ email: string;
3
+ }
4
+ export declare const sendTokenValidators: {
5
+ email: import("@os-team/graphql-validators").Validator[];
6
+ };
7
+ export declare const sendTokenTransformers: {
8
+ email: import("@os-team/graphql-transformers").Transformer[];
9
+ };
10
+ export default SendTokenInput;
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.sendTokenTransformers = exports.sendTokenValidators = void 0;
13
+ const type_graphql_1 = require("type-graphql");
14
+ const graphql_validators_1 = require("@os-team/graphql-validators");
15
+ const graphql_transformers_1 = require("@os-team/graphql-transformers");
16
+ let SendTokenInput = class SendTokenInput {
17
+ };
18
+ __decorate([
19
+ (0, type_graphql_1.Field)(),
20
+ __metadata("design:type", String)
21
+ ], SendTokenInput.prototype, "email", void 0);
22
+ SendTokenInput = __decorate([
23
+ (0, type_graphql_1.InputType)()
24
+ ], SendTokenInput);
25
+ exports.sendTokenValidators = {
26
+ email: [graphql_validators_1.isNotEmpty, graphql_validators_1.isEmail],
27
+ };
28
+ exports.sendTokenTransformers = {
29
+ email: [graphql_transformers_1.trim, graphql_transformers_1.toLowerCase],
30
+ };
31
+ exports.default = SendTokenInput;
@@ -1,4 +1,4 @@
1
1
  export default class SendTokenPayload {
2
- recoveryLinkIsSent: boolean;
2
+ codeIsSent: boolean;
3
3
  limitExpiresAt?: number;
4
4
  }
@@ -15,7 +15,7 @@ let SendTokenPayload = class SendTokenPayload {
15
15
  __decorate([
16
16
  (0, type_graphql_1.Field)(),
17
17
  __metadata("design:type", Boolean)
18
- ], SendTokenPayload.prototype, "recoveryLinkIsSent", void 0);
18
+ ], SendTokenPayload.prototype, "codeIsSent", void 0);
19
19
  __decorate([
20
20
  (0, type_graphql_1.Field)(() => Number, { nullable: true }),
21
21
  __metadata("design:type", Number)
@@ -8,4 +8,5 @@ export { default as SendTokenPayload } from './SendTokenPayload';
8
8
  export { default as UpdatePasswordInput, updatePasswordTransformers, updatePasswordValidators } from './UpdatePasswordInput';
9
9
  export { default as UpdateEmailInput, updateEmailTransformers, updateEmailValidators } from './UpdateEmailInput';
10
10
  export { default as UpdateProfileInput, updateProfileTransformers, updateProfileValidators } from './UpdateProfileInput';
11
+ export { default as SendTokenInput, sendTokenTransformers, sendTokenValidators } from './SendTokenInput';
11
12
  export { default as RecoverPasswordInput, recoverPasswordTransformers, recoverPasswordValidators } from './RecoverPasswordInput';
package/dist/dto/index.js CHANGED
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.recoverPasswordValidators = exports.recoverPasswordTransformers = exports.RecoverPasswordInput = exports.updateProfileValidators = exports.updateProfileTransformers = exports.UpdateProfileInput = exports.updateEmailValidators = exports.updateEmailTransformers = exports.UpdateEmailInput = exports.updatePasswordValidators = exports.updatePasswordTransformers = exports.UpdatePasswordInput = exports.SendTokenPayload = exports.StatusPayload = exports.confirmEmailValidators = exports.ConfirmEmailInput = exports.forgotPasswordValidators = exports.forgotPasswordTransformers = exports.ForgotPasswordInput = exports.loginValidators = exports.loginTransformers = exports.LoginInput = exports.registerValidators = exports.registerTransformers = exports.RegisterInput = exports.passwordValidators = exports.passwordTransformers = exports.PasswordInput = void 0;
6
+ exports.recoverPasswordValidators = exports.recoverPasswordTransformers = exports.RecoverPasswordInput = exports.sendTokenValidators = exports.sendTokenTransformers = exports.SendTokenInput = exports.updateProfileValidators = exports.updateProfileTransformers = exports.UpdateProfileInput = exports.updateEmailValidators = exports.updateEmailTransformers = exports.UpdateEmailInput = exports.updatePasswordValidators = exports.updatePasswordTransformers = exports.UpdatePasswordInput = exports.SendTokenPayload = exports.StatusPayload = exports.confirmEmailValidators = exports.ConfirmEmailInput = exports.forgotPasswordValidators = exports.forgotPasswordTransformers = exports.ForgotPasswordInput = exports.loginValidators = exports.loginTransformers = exports.LoginInput = exports.registerValidators = exports.registerTransformers = exports.RegisterInput = exports.passwordValidators = exports.passwordTransformers = exports.PasswordInput = void 0;
7
7
  var PasswordInput_1 = require("./PasswordInput");
8
8
  Object.defineProperty(exports, "PasswordInput", { enumerable: true, get: function () { return __importDefault(PasswordInput_1).default; } });
9
9
  Object.defineProperty(exports, "passwordTransformers", { enumerable: true, get: function () { return PasswordInput_1.passwordTransformers; } });
@@ -39,6 +39,10 @@ var UpdateProfileInput_1 = require("./UpdateProfileInput");
39
39
  Object.defineProperty(exports, "UpdateProfileInput", { enumerable: true, get: function () { return __importDefault(UpdateProfileInput_1).default; } });
40
40
  Object.defineProperty(exports, "updateProfileTransformers", { enumerable: true, get: function () { return UpdateProfileInput_1.updateProfileTransformers; } });
41
41
  Object.defineProperty(exports, "updateProfileValidators", { enumerable: true, get: function () { return UpdateProfileInput_1.updateProfileValidators; } });
42
+ var SendTokenInput_1 = require("./SendTokenInput");
43
+ Object.defineProperty(exports, "SendTokenInput", { enumerable: true, get: function () { return __importDefault(SendTokenInput_1).default; } });
44
+ Object.defineProperty(exports, "sendTokenTransformers", { enumerable: true, get: function () { return SendTokenInput_1.sendTokenTransformers; } });
45
+ Object.defineProperty(exports, "sendTokenValidators", { enumerable: true, get: function () { return SendTokenInput_1.sendTokenValidators; } });
42
46
  var RecoverPasswordInput_1 = require("./RecoverPasswordInput");
43
47
  Object.defineProperty(exports, "RecoverPasswordInput", { enumerable: true, get: function () { return __importDefault(RecoverPasswordInput_1).default; } });
44
48
  Object.defineProperty(exports, "recoverPasswordTransformers", { enumerable: true, get: function () { return RecoverPasswordInput_1.recoverPasswordTransformers; } });
@@ -135,7 +135,26 @@ function createAuthResolver(deps) {
135
135
  yield logTelegramBot.sendError(`${user.email || user.urlSlug} запросил(а) восстановление пароля`);
136
136
  }
137
137
  return {
138
- recoveryLinkIsSent: res.ok,
138
+ codeIsSent: res.ok,
139
+ limitExpiresAt: res.limitExpiresAt,
140
+ };
141
+ });
142
+ }
143
+ sendToken(input, ctx) {
144
+ return __awaiter(this, void 0, void 0, function* () {
145
+ const { user, t } = ctx;
146
+ if (!user)
147
+ throw new Error(t('validation:error.unauthorized'));
148
+ const service = getAuthService();
149
+ if (yield service.db.isEmailTaken(input.email, user.id)) {
150
+ throw new Error(t('validation:auth.emailExists'));
151
+ }
152
+ const res = yield service.sendLink(user, 'confirmation');
153
+ if (logTelegramBot) {
154
+ yield logTelegramBot.sendError(`Отправлен код подтверждения ${input.email}`);
155
+ }
156
+ return {
157
+ codeIsSent: res.ok,
139
158
  limitExpiresAt: res.limitExpiresAt,
140
159
  };
141
160
  });
@@ -215,6 +234,16 @@ function createAuthResolver(deps) {
215
234
  __metadata("design:paramtypes", [dto_1.ForgotPasswordInput, Object]),
216
235
  __metadata("design:returntype", Promise)
217
236
  ], AuthResolver.prototype, "forgotPassword", null);
237
+ __decorate([
238
+ (0, graphql_transformers_1.TransformArgs)(dto_1.sendTokenTransformers, { arg: 'input' }),
239
+ (0, graphql_validators_1.ValidateArgs)(dto_1.sendTokenValidators, { arg: 'input', tKey: 'sendToken' }),
240
+ (0, type_graphql_1.Mutation)(() => dto_1.SendTokenPayload),
241
+ __param(0, (0, type_graphql_1.Arg)('input')),
242
+ __param(1, (0, type_graphql_1.Ctx)()),
243
+ __metadata("design:type", Function),
244
+ __metadata("design:paramtypes", [dto_1.SendTokenInput, Object]),
245
+ __metadata("design:returntype", Promise)
246
+ ], AuthResolver.prototype, "sendToken", null);
218
247
  __decorate([
219
248
  (0, graphql_transformers_1.TransformArgs)(dto_1.recoverPasswordTransformers, { arg: 'input' }),
220
249
  (0, graphql_validators_1.ValidateArgs)(dto_1.recoverPasswordValidators, { arg: 'input', tKey: 'recover' }),
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@skroz/profile-api",
3
- "version": "1.0.11",
3
+ "version": "1.0.12",
4
4
  "license": "MIT",
5
5
  "repository": "git@gitlab.com:skroz/libs/utils.git",
6
6
  "main": "dist/index.js",
@@ -43,5 +43,5 @@
43
43
  "type-graphql": "^1.1.1",
44
44
  "typeorm": "^0.2.45"
45
45
  },
46
- "gitHead": "7e51d709eca09ef48505153cb200ca3767859169"
46
+ "gitHead": "49e4b60af88db3e07b62591aed5d8086bd1f4c34"
47
47
  }
@@ -0,0 +1,18 @@
1
+ import { Field, InputType } from 'type-graphql';
2
+ import { isEmail, isNotEmpty } from '@os-team/graphql-validators';
3
+ import { toLowerCase, trim } from '@os-team/graphql-transformers';
4
+
5
+ @InputType()
6
+ class SendTokenInput {
7
+ @Field()
8
+ public email!: string;
9
+ }
10
+
11
+ export const sendTokenValidators = {
12
+ email: [isNotEmpty, isEmail],
13
+ };
14
+ export const sendTokenTransformers = {
15
+ email: [trim, toLowerCase],
16
+ };
17
+
18
+ export default SendTokenInput;
@@ -3,7 +3,7 @@ import { Field, ObjectType } from 'type-graphql';
3
3
  @ObjectType()
4
4
  export default class SendTokenPayload {
5
5
  @Field()
6
- recoveryLinkIsSent!: boolean;
6
+ public codeIsSent!: boolean;
7
7
 
8
8
  @Field(() => Number, { nullable: true })
9
9
  limitExpiresAt?: number;
package/src/dto/index.ts CHANGED
@@ -8,4 +8,5 @@ export { default as SendTokenPayload } from './SendTokenPayload';
8
8
  export { default as UpdatePasswordInput, updatePasswordTransformers, updatePasswordValidators } from './UpdatePasswordInput';
9
9
  export { default as UpdateEmailInput, updateEmailTransformers, updateEmailValidators } from './UpdateEmailInput';
10
10
  export { default as UpdateProfileInput, updateProfileTransformers, updateProfileValidators } from './UpdateProfileInput';
11
+ export { default as SendTokenInput, sendTokenTransformers, sendTokenValidators } from './SendTokenInput';
11
12
  export { default as RecoverPasswordInput, recoverPasswordTransformers, recoverPasswordValidators } from './RecoverPasswordInput';
@@ -24,6 +24,9 @@ import {
24
24
  recoverPasswordValidators,
25
25
  SendTokenPayload,
26
26
  confirmEmailValidators,
27
+ SendTokenInput,
28
+ sendTokenTransformers,
29
+ sendTokenValidators,
27
30
  } from '../dto';
28
31
 
29
32
  export interface AuthResolverDependencies<
@@ -201,7 +204,34 @@ export function createAuthResolver<
201
204
  }
202
205
 
203
206
  return {
204
- recoveryLinkIsSent: res.ok,
207
+ codeIsSent: res.ok,
208
+ limitExpiresAt: res.limitExpiresAt,
209
+ };
210
+ }
211
+
212
+ @TransformArgs(sendTokenTransformers, { arg: 'input' })
213
+ @ValidateArgs(sendTokenValidators, { arg: 'input', tKey: 'sendToken' })
214
+ @Mutation(() => SendTokenPayload)
215
+ async sendToken(@Arg('input') input: SendTokenInput, @Ctx() ctx: TContext) {
216
+ const { user, t } = ctx;
217
+ if (!user) throw new Error(t('validation:error.unauthorized'));
218
+
219
+ const service = getAuthService();
220
+
221
+ if (await service.db.isEmailTaken(input.email, user.id)) {
222
+ throw new Error(t('validation:auth.emailExists'));
223
+ }
224
+
225
+ const res = await service.sendLink(user, 'confirmation');
226
+
227
+ if (logTelegramBot) {
228
+ await logTelegramBot.sendError(
229
+ `Отправлен код подтверждения ${input.email}`
230
+ );
231
+ }
232
+
233
+ return {
234
+ codeIsSent: res.ok,
205
235
  limitExpiresAt: res.limitExpiresAt,
206
236
  };
207
237
  }