* refactor(registration): remove checkBanStatus method and related logic * fix(BaseService): streamline customer permission checks by consolidating conditions * bot: remove logger from context * refactor(bot): update conversation handling and middleware integration - Replaced the previous conversations middleware with the Grammy framework's implementation. - Introduced a loop to register custom conversations, enhancing the bot's conversation management capabilities. - Removed the addContact feature implementation from the add-contact file, streamlining the codebase. * feat(bot): add cancel command to conversation middleware - Implemented a '/cancel' command in the bot's conversation middleware to allow users to exit all conversations gracefully. - Removed the manual cancellation check from the addContact conversation, streamlining the code and improving user experience. * fix(bot): conversations register - disable minification in build configuration
66 lines
1.9 KiB
TypeScript
66 lines
1.9 KiB
TypeScript
import { getClientWithToken } from '../apollo/client';
|
|
import { ERRORS } from '../constants/errors';
|
|
import * as GQL from '../types';
|
|
import { type VariablesOf } from '@graphql-typed-document-node/core';
|
|
import { isCustomerBanned } from '@repo/utils/customer';
|
|
|
|
export class RegistrationService {
|
|
async createCustomer(variables: VariablesOf<typeof GQL.CreateCustomerDocument>) {
|
|
const { mutate } = await getClientWithToken();
|
|
|
|
const mutationResult = await mutate({
|
|
mutation: GQL.CreateCustomerDocument,
|
|
variables,
|
|
});
|
|
|
|
const error = mutationResult.errors?.at(0);
|
|
if (error) throw new Error(error.message);
|
|
|
|
return mutationResult.data;
|
|
}
|
|
|
|
async getCustomer(variables: VariablesOf<typeof GQL.GetCustomerDocument>) {
|
|
const { query } = await getClientWithToken();
|
|
|
|
const result = await query({
|
|
query: GQL.GetCustomerDocument,
|
|
variables,
|
|
});
|
|
|
|
const customer = result.data.customers.at(0);
|
|
|
|
return { customer };
|
|
}
|
|
|
|
async updateCustomer(variables: VariablesOf<typeof GQL.UpdateCustomerDocument>) {
|
|
// Проверяем бан для существующего пользователя
|
|
if (variables.documentId) {
|
|
const { query } = await getClientWithToken();
|
|
const result = await query({
|
|
query: GQL.GetCustomerDocument,
|
|
variables: { documentId: variables.documentId },
|
|
});
|
|
const customer = result.data.customers.at(0);
|
|
if (customer && isCustomerBanned(customer)) {
|
|
throw new Error(ERRORS.NO_PERMISSION);
|
|
}
|
|
}
|
|
|
|
if (variables.data.bannedUntil) {
|
|
throw new Error(ERRORS.NO_PERMISSION);
|
|
}
|
|
|
|
const { mutate } = await getClientWithToken();
|
|
|
|
const mutationResult = await mutate({
|
|
mutation: GQL.UpdateCustomerDocument,
|
|
variables,
|
|
});
|
|
|
|
const error = mutationResult.errors?.at(0);
|
|
if (error) throw new Error(error.message);
|
|
|
|
return mutationResult.data;
|
|
}
|
|
}
|