# Simple Telegram Bot logger from __future__ import absolute_import, division import urllib3 import certifi from twisted.python import log import cowrie.core.output from cowrie.core.config import CowrieConfig class Output(cowrie.core.output.Output): """ telegram output """ #api telegram def start(self): self.bot_id = CowrieConfig().get('output_telegram', 'bot_id') self.chat_id = CowrieConfig().get('output_telegram', 'chat_id') def stop(self): pass #mangimbil log def write(self, logentry): for i in list(logentry.keys()): # remove twisted 15 legacy keys if i.startswith('log_'): del logentry[i] #kirim pesan if "login attempt" in logentry['message']: msgtxt = "[cowrie] " + logentry['timestamp'] msgtxt += " " + logentry['message'] msgtxt += " (session " + logentry['session'] + ")" #mengirim alert try: https = urllib3.PoolManager(cert_reqs='CERT_REQUIRED' , ca_certs=certifi.where()) r = https.request('GET', 'https://api.telegram.org/bot' + self.bot_id + '/sendMessage?chat_id=' + str(self.chat_id) + '&text=' + msgtxt) except urllib3.exceptions.SSLError as err: print('[ERROR] Telegram SSL error', err)