1
0
Fork 0
mirror of https://github.com/muerwre/vk-tg-bot.git synced 2025-04-25 15:06:41 +07:00

Merge remote-tracking branch 'origin/master'

# Conflicts:
#	src/service/vk/handlers/MessageNewHandler.ts
This commit is contained in:
Fedor Katurov 2021-04-29 11:34:20 +07:00
commit eb696e64d4
15 changed files with 573 additions and 29 deletions

View file

@ -1,5 +1,5 @@
import { ConfigGroup, GroupInstance, VkConfig, VkEvent } from "./types";
import { API, Upload, Updates } from "vk-io";
import { API, Updates, Upload } from "vk-io";
import logger from "../logger";
import { Request, Response } from "express";
import { flatten, has, keys } from "ramda";
@ -7,6 +7,8 @@ import { NextFunction } from "connect";
import { VkEventHandler } from "./handlers/VkEventHandler";
import { vkEventToHandler } from "./handlers";
import { TelegramService } from "../telegram";
import { Template } from "../template";
import { TemplateConfig } from "../../config/types";
/**
* Service to handle VK to Telegram interactions
@ -16,7 +18,11 @@ export class VkService {
private readonly instances: Record<string, GroupInstance>;
private readonly groups: Record<number, ConfigGroup>;
constructor(private config: VkConfig, private telegram: TelegramService) {
constructor(
private config: VkConfig,
private telegram: TelegramService,
private templates: TemplateConfig
) {
if (!config.groups.length) {
throw new Error("No vk groups to handle. Specify them in config");
}
@ -107,11 +113,16 @@ export class VkService {
return flatten(
group.channels.map((chan) =>
chan.events.reduce((acc, event) => {
const handler = new (vkEventToHandler as any)[event](
const template = new Template(this.templates[event]);
const handler = new vkEventToHandler[event](
event,
group,
chan.id,
instance,
this,
this.telegram
this.telegram,
template
);
return { ...acc, [event]: handler };
}, {} as Record<VkEvent, VkEventHandler>[])