UNPKG

vk-chat-bot

Version:

Package for easy creation of chat bots for VK communities (uses Callback API).

3 lines (2 loc) 13.9 kB
"use strict";var __awaiter=this&&this.__awaiter||function(t,e,i,s){return new(i||(i=Promise))((function(n,r){function o(t){try{h(s.next(t))}catch(t){r(t)}}function a(t){try{h(s.throw(t))}catch(t){r(t)}}function h(t){var e;t.done?n(t.value):(e=t.value,e instanceof i?e:new i((function(t){t(e)}))).then(o,a)}h((s=s.apply(t,e||[])).next())}))};Object.defineProperty(exports,"__esModule",{value:!0});const log_1=require("../extra/log"),keyboard_1=require("./keyboard");class Context{constructor(t,e,i,s){this.autoSend=!0,this.api=t,this.obj=i,this.msg=s,this.eventType=e,this.clear()}clear(){this.replyText="",this.attachment=[],this.kbdObject="",this.pid=this.getOriginalPid()}noAutoSend(){this.autoSend=!1}needsAutoSend(){return this.autoSend}getPid(){return this.pid}setPid(t){this.pid=t.toString()}getOriginalPid(){const t=this.eventType,e=this.obj;return"message_allow"===t?e.user_id:"message_typing_state"===t?e.from_id:e.peer_id}text(t){this.replyText=t}attach(t,e,i,s){s?this.attachment.push(`${t}${e}_${i}_${s}`):this.attachment.push(`${t}${e}_${i}`)}keyboard(t){this.kbdObject=JSON.stringify(t)}removeKeyboard(){this.keyboard(new keyboard_1.Keyboard)}send(){return __awaiter(this,void 0,void 0,(function*(){if("message_deny"===this.eventType)return void log_1.log().w(`No message was sent to peer ${this.pid} ("message_deny" event)`).from("ctx").now();if(""===this.replyText&&this.attachment===[])return void log_1.log().w(`No message was sent to peer ${this.pid} (text or attachment is required)`).from("ctx").now();const t=this.attachment.join(",");return this.api.send(this.pid,this.replyText,t,this.kbdObject)}))}}exports.default=Context; //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["api/context.js","api/context.ts"],"names":["__awaiter","this","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","Object","defineProperty","exports","log_1","require","keyboard_1","Context","[object Object]","api","eventType","object","message","autoSend","obj","msg","clear","replyText","attachment","kbdObject","pid","getOriginalPid","toString","user_id","from_id","peer_id","txt","type","ownerId","resId","accessKey","push","kbd","JSON","stringify","keyboard","Keyboard","log","w","from","now","attachmentList","join","send","default"],"mappings":"AAAA,aACA,IAAIA,UAAaC,MAAQA,KAAKD,WAAc,SAAUE,EAASC,EAAYC,EAAGC,GAE1E,OAAO,IAAKD,IAAMA,EAAIE,WAAU,SAAUC,EAASC,GAC/C,SAASC,EAAUC,GAAS,IAAMC,EAAKN,EAAUO,KAAKF,IAAW,MAAOG,GAAKL,EAAOK,IACpF,SAASC,EAASJ,GAAS,IAAMC,EAAKN,EAAiB,MAAEK,IAAW,MAAOG,GAAKL,EAAOK,IACvF,SAASF,EAAKI,GAJlB,IAAeL,EAIaK,EAAOC,KAAOT,EAAQQ,EAAOL,QAJ1CA,EAIyDK,EAAOL,MAJhDA,aAAiBN,EAAIM,EAAQ,IAAIN,GAAE,SAAUG,GAAWA,EAAQG,OAITO,KAAKR,EAAWK,GAClGH,GAAMN,EAAYA,EAAUa,MAAMhB,EAASC,GAAc,KAAKS,YAGtEO,OAAOC,eAAeC,QAAS,aAAc,CAAEX,OAAO,ICVtD,MAAAY,MAAAC,QAAA,gBAEAC,WAAAD,QAAA,cAKA,MAAqBE,QA8DjBC,YAAmBC,EAAUC,EAAmBC,EAAgBC,GA/BxD7B,KAAA8B,UAAW,EAgCf9B,KAAK0B,IAAMA,EACX1B,KAAK+B,IAAMH,EACX5B,KAAKgC,IAAMH,EACX7B,KAAK2B,UAAYA,EACjB3B,KAAKiC,QAQFR,QACHzB,KAAKkC,UAAY,GACjBlC,KAAKmC,WAAa,GAClBnC,KAAKoC,UAAY,GACjBpC,KAAKqC,IAAMrC,KAAKsC,iBAMbb,aACHzB,KAAK8B,UAAW,EAMbL,gBACH,OAAOzB,KAAK8B,SAMTL,SACH,OAAOzB,KAAKqC,IAQTZ,OAAOY,GACVrC,KAAKqC,IAAMA,EAAIE,WAMZd,iBACH,MAAME,EAAY3B,KAAK2B,UACjBI,EAAM/B,KAAK+B,IAEjB,MAAkB,kBAAdJ,EACOI,EAAIS,QACU,yBAAdb,EACAI,EAAIU,QAEJV,EAAIW,QASZjB,KAAKkB,GACR3C,KAAKkC,UAAYS,EAedlB,OACHmB,EACAC,EACAC,EACAC,GAEIA,EACA/C,KAAKmC,WAAWa,KAAK,GAAGJ,IAAOC,KAAWC,KAASC,KAEnD/C,KAAKmC,WAAWa,KAAK,GAAGJ,IAAOC,KAAWC,KAiC3CrB,SAASwB,GACZjD,KAAKoC,UAAYc,KAAKC,UAAUF,GAM7BxB,iBACHzB,KAAKoD,SAAS,IAAI7B,WAAA8B,UAQT5B,OD/IT,OAAO1B,UAAUC,UAAM,OAAQ,GAAQ,YCgJvC,GAAuB,iBAAnBA,KAAK2B,UAKL,YAJAN,MAAAiC,MACKC,EAAE,+BAA+BvD,KAAKqC,8BACtCmB,KAAK,OACLC,MAIT,GAAuB,KAAnBzD,KAAKkC,WAAoBlC,KAAKmC,aAAe,GAK7C,YAJAd,MAAAiC,MACKC,EAAE,+BAA+BvD,KAAKqC,wCACtCmB,KAAK,OACLC,MAIT,MAAMC,EAAiB1D,KAAKmC,WAAWwB,KAAK,KAG5C,OAAO3D,KAAK0B,IAAIkC,KACZ5D,KAAKqC,IACLrC,KAAKkC,UACLwB,EACA1D,KAAKoC,eAvOjBhB,QAAAyC,QAAArC","file":"api/context.js","sourcesContent":[null,"import { log } from '../extra/log';\nimport API from './api';\nimport { Keyboard } from './keyboard';\n\n/**\n * Context, which is passed to every handler.\n */\nexport default class Context {\n    /**\n     * API.\n     */\n    public readonly api: API;\n\n    /**\n     * Full object passed by Callback API.\n     *\n     * **Note:** If `message_new`, `message_reply`, `message_edit` or `no_match` event,\n     * this is a [Private message object](https://vk.com/dev/objects/message).\n     * Else, see [Callback API docs](https://vk.com/dev/callback_api) or\n     * [Groups Events docs](https://vk.com/dev/groups_events) for more information.\n     */\n    public readonly obj: any; // eslint-disable-line @typescript-eslint/no-explicit-any\n\n    /**\n     * Incoming user message.\n     *\n     * **Note:** If [[Core.cmd]] handler, contains message without `cmd_prefix` and the command\n     */\n    public msg: string; // TODO: Should be readonly\n\n    /**\n     * Name of the event.\n     */\n    public readonly eventType: string;\n\n    /**\n     * Does this [[Context]]'s response need auto-sending?\n     */\n    private autoSend = true;\n\n    /**\n     * The ID of a peer, to which the reply is going to be sent\n     *\n     * **Note:** You can change this using [[setPid]] method,\n     * the original Peer ID can be obtained using [[getOriginalPid]].\n     */\n    private pid: string;\n\n    /**\n     * Text, which will be used in the reply\n     */\n    private replyText: string;\n\n    /**\n     * Attachments, which will be used in the reply\n     */\n    private attachment: string[];\n\n    /**\n     * Object of the [[Keyboard]], which will be used in the reply\n     */\n    private kbdObject: string;\n\n    /**\n     * @param api the API object\n     * @param eventType the event type\n     * @param object full object from Callback API\n     * @param message the message\n     */\n    public constructor(api: API, eventType: string, object: object, message: string) {\n        this.api = api;\n        this.obj = object;\n        this.msg = message;\n        this.eventType = eventType;\n        this.clear();\n    }\n\n    /**\n     * Clears the buffer and resets the Peer ID back to original.\n     *\n     * For example, after calling this you can compose another message to the same user.\n     */\n    public clear(): void {\n        this.replyText = '';\n        this.attachment = [];\n        this.kbdObject = '';\n        this.pid = this.getOriginalPid();\n    }\n\n    /**\n     * Prevents this handler from sending the message automatically after it finishes.\n     */\n    public noAutoSend(): void {\n        this.autoSend = false;\n    }\n\n    /**\n     * Does this [[Context]]'s response need auto-sending?\n     */\n    public needsAutoSend(): boolean {\n        return this.autoSend;\n    }\n\n    /**\n     * Returns the current peer ID.\n     */\n    public getPid(): string {\n        return this.pid;\n    }\n\n    /**\n     * Sets a new peer ID.\n     *\n     * @param pid new peer ID\n     */\n    public setPid(pid: string | number): void {\n        this.pid = pid.toString();\n    }\n\n    /**\n     * Returns the original peer ID from the Callback API object.\n     */\n    public getOriginalPid(): string {\n        const eventType = this.eventType;\n        const obj = this.obj;\n\n        if (eventType === 'message_allow') {\n            return obj.user_id;\n        } else if (eventType === 'message_typing_state') {\n            return obj.from_id;\n        } else {\n            return obj.peer_id;\n        }\n    }\n\n    /**\n     * Sets the reply message text.\n     *\n     * @param txt new text\n     */\n    public text(txt: string): void {\n        this.replyText = txt;\n    }\n\n    /**\n     * Adds an attachment to the message.\n     *\n     * **Note:** More information on the parameters can be found in\n     * [VK API docs](https://vk.com/dev/messages.send).\n     *\n     * @param type the type of attachment\n     * @param ownerId resource owner ID\n     * @param resId resource ID\n     * @param accessKey resource access key, if needed;\n     * see [Access Key](https://vk.com/dev/access_key) page in API docs for more information\n     */\n    public attach(\n        type: string,\n        ownerId: string | number,\n        resId: string | number,\n        accessKey?: string,\n    ): void {\n        if (accessKey) {\n            this.attachment.push(`${type}${ownerId}_${resId}_${accessKey}`);\n        } else {\n            this.attachment.push(`${type}${ownerId}_${resId}`);\n        }\n    }\n\n    /**\n     * Attaches a keyboard.\n     *\n     * @param kbd the keyboard\n     *\n     * @example\n     * ```\n     * const { Color, Keyboard, button } = vk.kbd;\n     *\n     * core.cmd('keyboard', $ => {\n     *     // Set 'true' instead of 'false' to make it disappear after a button was pressed\n     *     var kbd = new Keyboard([\n     *         // Rows\n     *         [\n     *             button.text('Default'),\n     *             button.text('Primary', Color.Primary),\n     *             button.text('Negative', Color.Negative),\n     *             button.text('Positive', Color.Positive)\n     *         ],\n     *         [\n     *             button.text('Maximum rows is 10, columns - 4.')\n     *         ],\n     *    ], false);\n     *\n     *    $.text('Here is your keyboard, as promised.');\n     *    $.keyboard(kbd);\n     * }, 'demo keyboard');\n     * ```\n     */\n    public keyboard(kbd: Keyboard): void {\n        this.kbdObject = JSON.stringify(kbd);\n    }\n\n    /**\n     * Attaches an empty keyboard.\n     */\n    public removeKeyboard(): void {\n        this.keyboard(new Keyboard());\n    }\n\n    /**\n     * Sends the composed message to user.\n     * **Note:** After the handler finishes its work, this method is called automatically\n     * (if [[noAutoSend]] was not called)\n     */\n    public async send(): Promise<void> {\n        if (this.eventType === 'message_deny') {\n            log()\n                .w(`No message was sent to peer ${this.pid} (\"message_deny\" event)`)\n                .from('ctx')\n                .now();\n            return;\n        }\n\n        if (this.replyText === '' && this.attachment === []) {\n            log()\n                .w(`No message was sent to peer ${this.pid} (text or attachment is required)`)\n                .from('ctx')\n                .now();\n            return;\n        }\n\n        const attachmentList = this.attachment.join(',');\n\n        /* eslint-disable-next-line consistent-return */\n        return this.api.send(\n            this.pid,\n            this.replyText,\n            attachmentList,\n            this.kbdObject,\n        );\n    }\n}\n"]}