vk-chat-bot
Version:
Package for easy creation of chat bots for VK communities (uses Callback API).
3 lines (2 loc) • 12.7 kB
JavaScript
"use strict";var __importDefault=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(exports,"__esModule",{value:!0});const chalk_1=__importDefault(require("chalk")),io_ts_reporters_1=require("io-ts-reporters"),Either_1=require("fp-ts/lib/Either");var MessageType;!function(e){e[e.Information=0]="Information",e[e.Warning=1]="Warning",e[e.Error=2]="Error",e[e.Response=3]="Response"}(MessageType=exports.MessageType||(exports.MessageType={}));const SRC_SPACING=5;class LogMessageBuilder{constructor(){this.messageFrom="log",this.messageType=MessageType.Information,this.messageText=""}from(e){return this.messageFrom=e,this}type(e){return this.messageType=e,this}text(e){return e instanceof Error?this.messageText=e.message:this.messageText=e,this}now(){return this.log(),this}log(){if(""===this.messageText)return;const e=[chalk_1.default.bold.blue("info"),chalk_1.default.bold.keyword("orange")("warn"),chalk_1.default.bold.red("err!"),chalk_1.default.bold.green("resp")][this.messageType];let t="";for(let e=0;e<SRC_SPACING-this.messageFrom.length;e+=1)t+=" ";const s=`${t}${this.messageFrom} ${e} ${this.messageText}`;if(this.messageType===MessageType.Error)throw new Error(s);console.log(s)}i(e){return this.type(MessageType.Information),this.text(e)}w(e){return this.type(MessageType.Warning),this.text(e)}e(e){return this.type(MessageType.Error),this.text(e)}r(e){return this.type(MessageType.Response),this.text(e)}}function log(){return new LogMessageBuilder}function validate(e,t,s){const r=e.decode(t),o=io_ts_reporters_1.reporter(r);if(Either_1.isLeft(r)){o.unshift("The following errors occured during validation in `"+s+"`:");let e=o.join("\n "),t=/Expecting (\w+) at (\w+)\.0 but instead got: (.+)\.\n *Expecting (\w+) at \w+\.1 but instead got: (.+)\./g;return e=e.replace(t,chalk_1.default`Expecting {bold.blue $1} or {bold.blue $4} at {bold.green $2} but instead got {bold.red $3}`),t=/Expecting (\w+) at (\w+) but instead got: (.+)\./g,e=e.replace(t,chalk_1.default`Expecting {bold.blue $1} at {bold.green $2} but instead got {bold.red $3}`),log().e(e).from("•_•").now(),null}return r.right}exports.log=log,exports.validate=validate;
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["extra/log.js","extra/log.ts"],"names":["__importDefault","this","mod","__esModule","default","Object","defineProperty","exports","value","chalk_1","require","io_ts_reporters_1","Either_1","MessageType","SRC_SPACING","LogMessageBuilder","[object Object]","messageFrom","messageType","Information","messageText","f","t","Error","message","log","messageTypeString","bold","blue","keyword","red","green","spacing","i","length","console","type","text","Warning","Response","validate","validator","data","location","result","decode","report","reporter","isLeft","unshift","newReport","join","regex","replace","e","from","now","right"],"mappings":"AAAA,aACA,IAAIA,gBAAmBC,MAAQA,KAAKD,iBAAoB,SAAUE,GAC9D,OAAQA,GAAOA,EAAIC,WAAcD,EAAM,CAAEE,QAAWF,IAExDG,OAAOC,eAAeC,QAAS,aAAc,CAAEC,OAAO,ICJtD,MAAAC,QAAAT,gBAAAU,QAAA,UAEAC,kBAAAD,QAAA,mBACAE,SAAAF,QAAA,oBAKA,IAAYG,aAAZ,SAAYA,GACRA,EAAAA,EAAA,YAAA,GAAA,cACAA,EAAAA,EAAA,QAAA,GAAA,UACAA,EAAAA,EAAA,MAAA,GAAA,QACAA,EAAAA,EAAA,SAAA,GAAA,WAJJ,CAAYA,YAAAN,QAAAM,cAAAN,QAAAM,YAAW,KAUvB,MAAMC,YAAc,EAEpB,MAAMC,kBAANC,cAIWf,KAAAgB,YAAc,MAKdhB,KAAAiB,YAA2BL,YAAYM,YAKvClB,KAAAmB,YAAc,GAKdJ,KAAKK,GAER,OADApB,KAAKgB,YAAcI,EACZpB,KAMJe,KAAKM,GAER,OADArB,KAAKiB,YAAcI,EACZrB,KAMJe,KAAKM,GAOR,OANIA,aAAaC,MACbtB,KAAKmB,YAAcE,EAAEE,QAErBvB,KAAKmB,YAAcE,EAGhBrB,KAMJe,MAEH,OADAf,KAAKwB,MACExB,KAMJe,MACH,GAAyB,KAArBf,KAAKmB,YACL,OAGJ,MAAMM,EAAoB,CACtBjB,QAAAL,QAAMuB,KAAKC,KAAK,QAChBnB,QAAAL,QAAMuB,KAAKE,QAAQ,SAAnBpB,CAA6B,QAC7BA,QAAAL,QAAMuB,KAAKG,IAAI,QACfrB,QAAAL,QAAMuB,KAAKI,MAAM,SACnB9B,KAAKiB,aAEP,IAAIc,EAAU,GACd,IAAK,IAAIC,EAAI,EAAGA,EAAInB,YAAcb,KAAKgB,YAAYiB,OAAQD,GAAK,EAC5DD,GAAW,IAGf,MAAMR,EAAU,GAAGQ,IAAU/B,KAAKgB,eAAeS,KAAqBzB,KAAKmB,cAE3E,GAAInB,KAAKiB,cAAgBL,YAAYU,MACjC,MAAM,IAAIA,MAAMC,GAEhBW,QAAQV,IAAID,GAUbR,EAAEM,GAEL,OADArB,KAAKmC,KAAKvB,YAAYM,aACflB,KAAKoC,KAAKf,GASdN,EAAEM,GAEL,OADArB,KAAKmC,KAAKvB,YAAYyB,SACfrC,KAAKoC,KAAKf,GASdN,EAAEM,GAEL,OADArB,KAAKmC,KAAKvB,YAAYU,OACftB,KAAKoC,KAAKf,GASdN,EAAEM,GAEL,OADArB,KAAKmC,KAAKvB,YAAY0B,UACftC,KAAKoC,KAAKf,IAOzB,SAAgBG,MACZ,OAAO,IAAIV,kBAOf,SAAgByB,SAAkBC,EAA4BC,EAAWC,GACrE,MAAMC,EAASH,EAAUI,OAAOH,GAC1BI,EAASnC,kBAAAoC,SAASH,GAExB,GAAIhC,SAAAoC,OAAOJ,GAAS,CAChBE,EAAOG,QAAQ,sDAAwDN,EAAW,MAElF,IAAIO,EAAYJ,EAAOK,KAAK,mBACxBC,EAAQ,4GAQZ,OAPAF,EAAYA,EAAUG,QAAQD,EAAO3C,QAAAL,OAAK,+FAE1CgD,EAAQ,oDACRF,EAAYA,EAAUG,QAAQD,EAAO3C,QAAAL,OAAK,6EAE1CqB,MAAM6B,EAAEJ,GAAWK,KAAK,OAAOC,MAExB,KAEP,OAAOZ,EAAOa,MA1BtBlD,QAAAkB,IAAAA,IAQAlB,QAAAiC,SAAAA","file":"extra/log.js","sourcesContent":[null,"import chalk from 'chalk';\nimport * as t from 'io-ts'\nimport { reporter } from 'io-ts-reporters';\nimport { isLeft } from 'fp-ts/lib/Either'\n\n/**\n * Types of log messages.\n */\nexport enum MessageType {\n    Information = 0,\n    Warning = 1,\n    Error = 2,\n    Response = 3,\n}\n\n/**\n * Spacing of the message source.\n */\nconst SRC_SPACING = 5;\n\nclass LogMessageBuilder {\n    /**\n     * The source of the message.\n     */\n    public messageFrom = 'log';\n\n    /**\n     * The type of the message.\n     */\n    public messageType: MessageType = MessageType.Information;\n\n    /**\n     * The text of the message.\n     */\n    public messageText = '';\n\n    /**\n     * Sets the source of the message.\n     */\n    public from(f: string): LogMessageBuilder {\n        this.messageFrom = f;\n        return this;\n    }\n\n    /**\n     * Sets the type of the message.\n     */\n    public type(t: MessageType): LogMessageBuilder {\n        this.messageType = t;\n        return this;\n    }\n\n    /**\n     * Sets the text of the message.\n     */\n    public text(t: string | Error): LogMessageBuilder {\n        if (t instanceof Error) {\n            this.messageText = t.message;\n        } else {\n            this.messageText = t;\n        }\n\n        return this;\n    }\n\n    /**\n     * Logs the message now.\n     */\n    public now(): LogMessageBuilder {\n        this.log();\n        return this;\n    }\n\n    /**\n     * Logs the message.\n     */\n    public log(): void {\n        if (this.messageText === '') {\n            return;\n        }\n\n        const messageTypeString = [\n            chalk.bold.blue('info'),\n            chalk.bold.keyword('orange')('warn'),\n            chalk.bold.red('err!'),\n            chalk.bold.green('resp'),\n        ][this.messageType];\n\n        let spacing = '';\n        for (let i = 0; i < SRC_SPACING - this.messageFrom.length; i += 1) {\n            spacing += ' ';\n        }\n\n        const message = `${spacing}${this.messageFrom} ${messageTypeString} ${this.messageText}`;\n\n        if (this.messageType === MessageType.Error) {\n            throw new Error(message);\n        } else {\n            console.log(message); // eslint-disable-line no-console\n        }\n    }\n\n    /**\n     * Convenience method for logging information.\n     * Sets the type to [[MessageType.Information]] and also the text of the message.\n     * @param t the text of the message. If passed an `Error`,\n     * the `message` property of the error will be used.\n     */\n    public i(t: string | Error): LogMessageBuilder {\n        this.type(MessageType.Information);\n        return this.text(t);\n    }\n\n    /**\n     * Convenience method for logging warnings.\n     * Sets the type to [[MessageType.Warning]] and also the text of the message.\n     * @param t the text of the message. If passed an `Error`,\n     * the `message` property of the error will be used.\n     */\n    public w(t: string | Error): LogMessageBuilder {\n        this.type(MessageType.Warning);\n        return this.text(t);\n    }\n\n    /**\n     * Convenience method for logging errors.\n     * Sets the type to [[MessageType.Error]] and also the text of the message.\n     * @param t the text of the message. If passed an `Error`,\n     * the `message` property of the error will be used.\n     */\n    public e(t: string | Error): LogMessageBuilder {\n        this.type(MessageType.Error);\n        return this.text(t);\n    }\n\n    /**\n     * Convenience method for logging responses.\n     * Sets the type to [[MessageType.Response]] and also the text of the message.\n     * @param t the text of the message. If passed an `Error`,\n     * the `message` property of the error will be used.\n     */\n    public r(t: string | Error): LogMessageBuilder {\n        this.type(MessageType.Response);\n        return this.text(t);\n    }\n}\n\n/**\n * Shortcut for constructing [[LogMessageBuilder]]s.\n */\nexport function log(): LogMessageBuilder {\n    return new LogMessageBuilder();\n}\n\n/**\n * Validates using `io-ts` and converts report from the `io-ts-reporters`\n * reporter to colorful format and joins lines with `.0` and `.1` using `or`.\n */\nexport function validate<A, O, I>(validator: t.Type<A, O, I>, data: any, location: string): any { // eslint-disable-line @typescript-eslint/no-explicit-any\n    const result = validator.decode(data);\n    const report = reporter(result);\n\n    if (isLeft(result)) {\n        report.unshift('The following errors occured during validation in `' + location + '`:');\n\n        let newReport = report.join('\\n             ');\n        let regex = /Expecting (\\w+) at (\\w+)\\.0 but instead got: (.+)\\.\\n *Expecting (\\w+) at \\w+\\.1 but instead got: (.+)\\./g;\n        newReport = newReport.replace(regex, chalk`Expecting {bold.blue $1} or {bold.blue $4} at {bold.green $2} but instead got {bold.red $3}`);\n\n        regex = /Expecting (\\w+) at (\\w+) but instead got: (.+)\\./g;\n        newReport = newReport.replace(regex, chalk`Expecting {bold.blue $1} at {bold.green $2} but instead got {bold.red $3}`);\n\n        log().e(newReport).from('•_•').now();\n\n        return null;\n    } else {\n        return result.right;\n    }\n}\n"]}