feat Types: Forward Type
This commit is contained in:
parent
c0308f5287
commit
5f07eaa456
@ -90,6 +90,7 @@ This will result in:
|
|||||||
# Todo
|
# Todo
|
||||||
|
|
||||||
- [x] Webhook support
|
- [x] Webhook support
|
||||||
|
- [x] Forward Type
|
||||||
- [ ] BulkMessage Type
|
- [ ] BulkMessage Type
|
||||||
- [ ] File Type
|
- [ ] File Type
|
||||||
- [ ] Sticker Type
|
- [ ] Sticker Type
|
||||||
|
@ -172,6 +172,13 @@ var Bot = (function (_EventEmitter) {
|
|||||||
}
|
}
|
||||||
}, {
|
}, {
|
||||||
key: '_update',
|
key: '_update',
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The internal update event listener, used to parse messages and fire
|
||||||
|
* command/get events - YOU SHOULD NOT USE THIS
|
||||||
|
*
|
||||||
|
* @param {object} update
|
||||||
|
*/
|
||||||
value: function _update(update) {
|
value: function _update(update) {
|
||||||
var _this2 = this;
|
var _this2 = this;
|
||||||
|
|
||||||
|
@ -19,16 +19,77 @@ var _events = require('events');
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var Base = (function (_EventEmitter) {
|
var Base = (function (_EventEmitter) {
|
||||||
function Base() {
|
function Base(method) {
|
||||||
_classCallCheck(this, Base);
|
_classCallCheck(this, Base);
|
||||||
|
|
||||||
_get(Object.getPrototypeOf(Base.prototype), 'constructor', this).call(this);
|
_get(Object.getPrototypeOf(Base.prototype), 'constructor', this).call(this);
|
||||||
|
|
||||||
|
this.method = method;
|
||||||
this.properties = {};
|
this.properties = {};
|
||||||
}
|
}
|
||||||
|
|
||||||
_inherits(Base, _EventEmitter);
|
_inherits(Base, _EventEmitter);
|
||||||
|
|
||||||
_createClass(Base, [{
|
_createClass(Base, [{
|
||||||
|
key: 'send',
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sends the message, you should only use this method yourself if
|
||||||
|
* you are extending this class. Normally you should call bot.send(message)
|
||||||
|
*
|
||||||
|
* Events: message:sent => Emitted after sending the message to API, gets the
|
||||||
|
* API's response
|
||||||
|
*
|
||||||
|
* message:answer => Emitted when your message gets an answer from
|
||||||
|
* the contact (reply in case of groups)
|
||||||
|
* gets the Update object containing message
|
||||||
|
*
|
||||||
|
* @param {object} bot
|
||||||
|
* @return {promise} returns a promise, resolved with message:answer
|
||||||
|
*/
|
||||||
|
value: function send(bot) {
|
||||||
|
var _this = this;
|
||||||
|
|
||||||
|
if (this._keyboard) {
|
||||||
|
var reply_markup = JSON.stringify(this._keyboard.getProperties());
|
||||||
|
this.properties.reply_markup = reply_markup;
|
||||||
|
}
|
||||||
|
|
||||||
|
var messageId = undefined;
|
||||||
|
return new Promise(function (resolve) {
|
||||||
|
bot.api[_this.method](_this.properties).then(function (response) {
|
||||||
|
messageId = response.result.message_id;
|
||||||
|
_this.emit('message:sent', response);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (_this._keyboard.one_time_keyboard) {
|
||||||
|
_this._keyboard.replyMarkup = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
var chat = _this.properties.chat_id;
|
||||||
|
bot.on('update', function listener(result) {
|
||||||
|
var update = result.find(function (_ref) {
|
||||||
|
var message = _ref.message;
|
||||||
|
|
||||||
|
// if in a group, there will be a reply to this message
|
||||||
|
if (chat < 0) {
|
||||||
|
return message.chat.id === chat && message.reply_to_message && message.reply_to_message.message_id === messageId;
|
||||||
|
} else {
|
||||||
|
return message.chat.id === chat;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
if (update) {
|
||||||
|
resolve(update.message);
|
||||||
|
|
||||||
|
this.emit('message:answer', update.message);
|
||||||
|
|
||||||
|
bot.removeListener('update', listener);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}, {
|
||||||
key: 'getProperties',
|
key: 'getProperties',
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
104
build/types/Forward.js
Normal file
104
build/types/Forward.js
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
Object.defineProperty(exports, '__esModule', {
|
||||||
|
value: true
|
||||||
|
});
|
||||||
|
|
||||||
|
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
||||||
|
|
||||||
|
var _get = function get(_x2, _x3, _x4) { var _again = true; _function: while (_again) { var object = _x2, property = _x3, receiver = _x4; desc = parent = getter = undefined; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x2 = parent; _x3 = property; _x4 = receiver; _again = true; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
|
||||||
|
|
||||||
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
||||||
|
|
||||||
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
||||||
|
|
||||||
|
function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) subClass.__proto__ = superClass; }
|
||||||
|
|
||||||
|
var _Base2 = require('./Base');
|
||||||
|
|
||||||
|
var _Base3 = _interopRequireDefault(_Base2);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Forward class, used to forward messages from a chat to another
|
||||||
|
*/
|
||||||
|
|
||||||
|
var Forward = (function (_Base) {
|
||||||
|
/**
|
||||||
|
* Create a new forward message
|
||||||
|
* @param {object} properties Forward Message properties, as defined by
|
||||||
|
* Telegram API
|
||||||
|
*/
|
||||||
|
|
||||||
|
function Forward() {
|
||||||
|
var properties = arguments[0] === undefined ? {} : arguments[0];
|
||||||
|
|
||||||
|
_classCallCheck(this, Forward);
|
||||||
|
|
||||||
|
_get(Object.getPrototypeOf(Forward.prototype), 'constructor', this).call(this, 'forwardMessage');
|
||||||
|
|
||||||
|
this.properties = properties;
|
||||||
|
this._keyboard = new _Base3['default']();
|
||||||
|
}
|
||||||
|
|
||||||
|
_inherits(Forward, _Base);
|
||||||
|
|
||||||
|
_createClass(Forward, [{
|
||||||
|
key: 'to',
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set chat_id of the message
|
||||||
|
* @param {number} chat
|
||||||
|
* @return {object} returns the message object
|
||||||
|
*/
|
||||||
|
value: function to(chat) {
|
||||||
|
this.properties.chat_id = chat;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: 'from',
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set from_chat_id, source of message's chat's id
|
||||||
|
* @param {number} chat Source chat id
|
||||||
|
* @return {object} returns the message object
|
||||||
|
*/
|
||||||
|
value: function from(chat) {
|
||||||
|
this.properties.from_chat_id = chat;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: 'message',
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets message_id, the message to forward from source to target chat
|
||||||
|
* @param {number} message ID of the message to forward
|
||||||
|
* @return {object} returns the message object
|
||||||
|
*/
|
||||||
|
value: function message(_message) {
|
||||||
|
this.properties.message_id = _message;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: 'keyboard',
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets keyboard of the message
|
||||||
|
* The value of reply_markup is set to the sanitized keyboard properties
|
||||||
|
* i.e. reply_markup = JSON.stringify(kb.getProperties())
|
||||||
|
* @param {object} kb A Keyboard instance
|
||||||
|
* @return {object} returns the message object
|
||||||
|
*/
|
||||||
|
value: function keyboard(kb) {
|
||||||
|
this._keyboard = kb;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This class inherits Base's send method
|
||||||
|
|
||||||
|
}]);
|
||||||
|
|
||||||
|
return Forward;
|
||||||
|
})(_Base3['default']);
|
||||||
|
|
||||||
|
exports['default'] = Forward;
|
||||||
|
module.exports = exports['default'];
|
@ -33,7 +33,7 @@ var Message = (function (_Base) {
|
|||||||
|
|
||||||
_classCallCheck(this, Message);
|
_classCallCheck(this, Message);
|
||||||
|
|
||||||
_get(Object.getPrototypeOf(Message.prototype), 'constructor', this).call(this);
|
_get(Object.getPrototypeOf(Message.prototype), 'constructor', this).call(this, 'sendMessage');
|
||||||
|
|
||||||
this.properties = properties;
|
this.properties = properties;
|
||||||
this._keyboard = new _Base3['default']();
|
this._keyboard = new _Base3['default']();
|
||||||
@ -91,65 +91,9 @@ var Message = (function (_Base) {
|
|||||||
this._keyboard = kb;
|
this._keyboard = kb;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
}, {
|
|
||||||
key: 'send',
|
|
||||||
|
|
||||||
/**
|
// This class inherits Base's send method
|
||||||
* Sends the message, you should only use this method yourself if
|
|
||||||
* you are extending this class. Normally you should call bot.send(message)
|
|
||||||
*
|
|
||||||
* Events: message:sent => Emitted after sending the message to API, gets the
|
|
||||||
* API's response
|
|
||||||
*
|
|
||||||
* message:answer => Emitted when your message gets an answer from
|
|
||||||
* the contact (reply in case of groups)
|
|
||||||
* gets the Update object containing message
|
|
||||||
*
|
|
||||||
* @param {object} bot
|
|
||||||
* @return {promise} returns a promise, resolved with message:answer
|
|
||||||
*/
|
|
||||||
value: function send(bot) {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
console.log('sending message');
|
|
||||||
|
|
||||||
var messageId = undefined;
|
|
||||||
var reply_markup = JSON.stringify(this._keyboard.getProperties());
|
|
||||||
this.properties.reply_markup = reply_markup;
|
|
||||||
|
|
||||||
return new Promise(function (resolve) {
|
|
||||||
bot.api.sendMessage(_this.properties).then(function (response) {
|
|
||||||
messageId = response.result.message_id;
|
|
||||||
_this.emit('message:sent', response);
|
|
||||||
});
|
|
||||||
|
|
||||||
if (_this._keyboard.one_time_keyboard) {
|
|
||||||
_this._keyboard.replyMarkup = '';
|
|
||||||
}
|
|
||||||
|
|
||||||
var chat = _this.properties.chat_id;
|
|
||||||
bot.on('update', function listener(result) {
|
|
||||||
var update = result.find(function (_ref) {
|
|
||||||
var message = _ref.message;
|
|
||||||
|
|
||||||
// if in a group, there will be a reply to this message
|
|
||||||
if (chat < 0) {
|
|
||||||
return message.chat.id === chat && message.reply_to_message && message.reply_to_message.message_id === messageId;
|
|
||||||
} else {
|
|
||||||
return message.chat.id === chat;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if (update) {
|
|
||||||
resolve(update.message);
|
|
||||||
|
|
||||||
this.emit('message:answer', update.message);
|
|
||||||
|
|
||||||
bot.removeListener('update', listener);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}]);
|
}]);
|
||||||
|
|
||||||
return Message;
|
return Message;
|
||||||
|
3
demo.js
3
demo.js
@ -5,7 +5,7 @@ var Message = require('telegram-api/types/Message');
|
|||||||
var Question = require('telegram-api/types/Question');
|
var Question = require('telegram-api/types/Question');
|
||||||
|
|
||||||
var bot = new Bot({
|
var bot = new Bot({
|
||||||
token: '121143906:AAE6pcpBoARNZZjr3fUpvKuLInJ5Eee5Ajk'
|
token: 'YOUR_KEY'
|
||||||
});
|
});
|
||||||
|
|
||||||
bot.start().catch(err => {
|
bot.start().catch(err => {
|
||||||
@ -42,6 +42,7 @@ bot.command('start', message => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
const test = new Message().text('Test Command');
|
const test = new Message().text('Test Command');
|
||||||
|
|
||||||
bot.command('test', message => {
|
bot.command('test', message => {
|
||||||
bot.send(test.to(message.chat.id));
|
bot.send(test.to(message.chat.id));
|
||||||
});
|
});
|
||||||
|
@ -4,11 +4,68 @@ import {EventEmitter} from 'events';
|
|||||||
* Base class of all classes
|
* Base class of all classes
|
||||||
*/
|
*/
|
||||||
export default class Base extends EventEmitter {
|
export default class Base extends EventEmitter {
|
||||||
constructor() {
|
constructor(method) {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
|
this.method = method;
|
||||||
this.properties = {};
|
this.properties = {};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sends the message, you should only use this method yourself if
|
||||||
|
* you are extending this class. Normally you should call bot.send(message)
|
||||||
|
*
|
||||||
|
* Events: message:sent => Emitted after sending the message to API, gets the
|
||||||
|
* API's response
|
||||||
|
*
|
||||||
|
* message:answer => Emitted when your message gets an answer from
|
||||||
|
* the contact (reply in case of groups)
|
||||||
|
* gets the Update object containing message
|
||||||
|
*
|
||||||
|
* @param {object} bot
|
||||||
|
* @return {promise} returns a promise, resolved with message:answer
|
||||||
|
*/
|
||||||
|
send(bot) {
|
||||||
|
if (this._keyboard) {
|
||||||
|
const reply_markup = JSON.stringify(this._keyboard.getProperties());
|
||||||
|
this.properties.reply_markup = reply_markup;
|
||||||
|
}
|
||||||
|
|
||||||
|
let messageId;
|
||||||
|
return new Promise(resolve => {
|
||||||
|
bot.api[this.method](this.properties).then(response => {
|
||||||
|
messageId = response.result.message_id;
|
||||||
|
this.emit('message:sent', response);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (this._keyboard.one_time_keyboard) {
|
||||||
|
this._keyboard.replyMarkup = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
const chat = this.properties.chat_id;
|
||||||
|
bot.on('update', function listener(result) {
|
||||||
|
const update = result.find(({message}) => {
|
||||||
|
// if in a group, there will be a reply to this message
|
||||||
|
if (chat < 0) {
|
||||||
|
return message.chat.id === chat
|
||||||
|
&& message.reply_to_message
|
||||||
|
&& message.reply_to_message.message_id === messageId;
|
||||||
|
} else {
|
||||||
|
return message.chat.id === chat;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
if (update) {
|
||||||
|
resolve(update.message);
|
||||||
|
|
||||||
|
this.emit('message:answer', update.message);
|
||||||
|
|
||||||
|
bot.removeListener('update', listener);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns properties of the object
|
* Returns properties of the object
|
||||||
* @return {object} properties of object
|
* @return {object} properties of object
|
||||||
|
62
lib/types/Forward.js
Normal file
62
lib/types/Forward.js
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
import Base from './Base';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Forward class, used to forward messages from a chat to another
|
||||||
|
*/
|
||||||
|
export default class Forward extends Base {
|
||||||
|
/**
|
||||||
|
* Create a new forward message
|
||||||
|
* @param {object} properties Forward Message properties, as defined by
|
||||||
|
* Telegram API
|
||||||
|
*/
|
||||||
|
constructor(properties = {}) {
|
||||||
|
super('forwardMessage');
|
||||||
|
|
||||||
|
this.properties = properties;
|
||||||
|
this._keyboard = new Base();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set chat_id of the message
|
||||||
|
* @param {number} chat
|
||||||
|
* @return {object} returns the message object
|
||||||
|
*/
|
||||||
|
to(chat) {
|
||||||
|
this.properties.chat_id = chat;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set from_chat_id, source of message's chat's id
|
||||||
|
* @param {number} chat Source chat id
|
||||||
|
* @return {object} returns the message object
|
||||||
|
*/
|
||||||
|
from(chat) {
|
||||||
|
this.properties.from_chat_id = chat;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets message_id, the message to forward from source to target chat
|
||||||
|
* @param {number} message ID of the message to forward
|
||||||
|
* @return {object} returns the message object
|
||||||
|
*/
|
||||||
|
message(message) {
|
||||||
|
this.properties.message_id = message;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets keyboard of the message
|
||||||
|
* The value of reply_markup is set to the sanitized keyboard properties
|
||||||
|
* i.e. reply_markup = JSON.stringify(kb.getProperties())
|
||||||
|
* @param {object} kb A Keyboard instance
|
||||||
|
* @return {object} returns the message object
|
||||||
|
*/
|
||||||
|
keyboard(kb) {
|
||||||
|
this._keyboard = kb;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This class inherits Base's send method
|
||||||
|
}
|
@ -9,7 +9,7 @@ export default class Message extends Base {
|
|||||||
* @param {object} properties Message properties, as defined by Telegram API
|
* @param {object} properties Message properties, as defined by Telegram API
|
||||||
*/
|
*/
|
||||||
constructor(properties = {}) {
|
constructor(properties = {}) {
|
||||||
super();
|
super('sendMessage');
|
||||||
|
|
||||||
this.properties = properties;
|
this.properties = properties;
|
||||||
this._keyboard = new Base();
|
this._keyboard = new Base();
|
||||||
@ -57,58 +57,5 @@ export default class Message extends Base {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
// This class inherits Base's send method
|
||||||
* Sends the message, you should only use this method yourself if
|
|
||||||
* you are extending this class. Normally you should call bot.send(message)
|
|
||||||
*
|
|
||||||
* Events: message:sent => Emitted after sending the message to API, gets the
|
|
||||||
* API's response
|
|
||||||
*
|
|
||||||
* message:answer => Emitted when your message gets an answer from
|
|
||||||
* the contact (reply in case of groups)
|
|
||||||
* gets the Update object containing message
|
|
||||||
*
|
|
||||||
* @param {object} bot
|
|
||||||
* @return {promise} returns a promise, resolved with message:answer
|
|
||||||
*/
|
|
||||||
send(bot) {
|
|
||||||
console.log('sending message');
|
|
||||||
|
|
||||||
let messageId;
|
|
||||||
const reply_markup = JSON.stringify(this._keyboard.getProperties());
|
|
||||||
this.properties.reply_markup = reply_markup;
|
|
||||||
|
|
||||||
return new Promise(resolve => {
|
|
||||||
bot.api.sendMessage(this.properties).then(response => {
|
|
||||||
messageId = response.result.message_id;
|
|
||||||
this.emit('message:sent', response);
|
|
||||||
});
|
|
||||||
|
|
||||||
if (this._keyboard.one_time_keyboard) {
|
|
||||||
this._keyboard.replyMarkup = '';
|
|
||||||
}
|
|
||||||
|
|
||||||
const chat = this.properties.chat_id;
|
|
||||||
bot.on('update', function listener(result) {
|
|
||||||
const update = result.find(({message}) => {
|
|
||||||
// if in a group, there will be a reply to this message
|
|
||||||
if (chat < 0) {
|
|
||||||
return message.chat.id === chat
|
|
||||||
&& message.reply_to_message
|
|
||||||
&& message.reply_to_message.message_id === messageId;
|
|
||||||
} else {
|
|
||||||
return message.chat.id === chat;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if (update) {
|
|
||||||
resolve(update.message);
|
|
||||||
|
|
||||||
this.emit('message:answer', update.message);
|
|
||||||
|
|
||||||
bot.removeListener('update', listener);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "telegram-api",
|
"name": "telegram-api",
|
||||||
"version": "0.3.2",
|
"version": "0.3.3",
|
||||||
"description": "Control Telegram bots easily using the new Telegram API",
|
"description": "Control Telegram bots easily using the new Telegram API",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
1
types/Forward.js
Symbolic link
1
types/Forward.js
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../build/types/Forward.js
|
Loading…
Reference in New Issue
Block a user