@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.
- package/dist/dto/SendTokenInput.d.ts +10 -0
- package/dist/dto/SendTokenInput.js +31 -0
- package/dist/dto/SendTokenPayload.d.ts +1 -1
- package/dist/dto/SendTokenPayload.js +1 -1
- package/dist/dto/index.d.ts +1 -0
- package/dist/dto/index.js +5 -1
- package/dist/resolvers/AuthResolver.js +30 -1
- package/package.json +2 -2
- package/src/dto/SendTokenInput.ts +18 -0
- package/src/dto/SendTokenPayload.ts +1 -1
- package/src/dto/index.ts +1 -0
- package/src/resolvers/AuthResolver.ts +31 -1
|
@@ -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;
|
|
@@ -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, "
|
|
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)
|
package/dist/dto/index.d.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';
|
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
|
-
|
|
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.
|
|
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": "
|
|
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;
|
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
|
-
|
|
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
|
}
|