#!/usr/bin/env node var cfgDir = (process.env.HOME || process.env.USERPROFILE) + '/.config/telecommander/' process.env.LOGGER_FILE = cfgDir+'log' var os = require('os') var fs = require('fs') var blessed = require('blessed') try { fs.makeDirSync(cfgDir,'0770') } catch (e) { } var getLogger = require('get-log') getLogger.PROJECT_NAME = 'telecommander' var logger = getLogger('main') var telegramLink = require('telegram.link')() var screen = blessed.screen({ smartCSR: true, dockBorders: true }) screen.title = "Telecommander" var defaultStyle = { fg: 'white', border: { fg: 'gray' }, } var chats = blessed.list({ left: 0, top:0, height: screen.height-3, width: '20%', border: { type: 'line' }, mouse: true, style: defaultStyle, }) chats.style.selected = { bg: 'black' } var msgs = blessed.log({ right: 0, width: '80%', height: screen.height-3, border: { type: 'line' }, style: defaultStyle }) var cmdline = blessed.textbox({ inputOnFocus: true, bottom: 0, left: 'center', width: '100%', height: 3, border: { type: 'line' }, style: defaultStyle }) screen.append(chats); screen.append(msgs); screen.append(cmdline); var msgBox = { } var contacts = { } var client,phone,code,phoneCodeHash,fullName,username,loginResult,uid,authKey var registered = false function command(cmd){ cmdname = cmd.split(' ')[0] if(cmdname === 'phone'){ phone = cmd.split(' ')[1] client.auth.sendCode(phone,5,'en',function(result){ log('Errors:',result.error_code,result.error_message) if(result.error_code) return log('Res:',JSON.stringify(result)) registered = result.phone_registered phoneCodeHash = result.phone_code_hash if(!registered){ log("Your number is not registered. The client will register your account with the Telegram service") log('Ready for phone code, use command: "code " to register') } else { log("Your number is already registered with telegram. The client will log in.") log('Ready for phone code, use command: "code " to login') } }) } else if(cmdname === 'code'){ cmdl = cmd.split(' ') code = cmdl[1] name = cmdl[2] lastname = cmdl[3] if(((!name || !lastname) && !registered) || !code) return log('insufficient arguments:',cmd) cb = function(result){ loginResult = result log('Result:',JSON.stringify(result)) whenReady() } // Log in finally if(registered) client.auth.signIn(phone,phoneCodeHash,code,cb) else client.auth.signUp(phone,phoneCodeHash,code,name,lastname,cb) } else if(cmdname === 'init'){ whenReady() } } cmdline.on('submit',function(value){ msgs.add('[ECHO] '+value) command(value) cmdline.clearValue() cmdline.focus() }) cmdline.focus() cmdline.key(['escape','C-c'], function(ch,key){ if(client){ log('Closing communications and shutting down...') client.end(function(){ process.exit(0) }) } else process.exit(0); }); screen.render(); function log(){ args = Array.prototype.slice.call(arguments) msg = args.join(' ') msgs.add(msg) logger.info(msg) } var app = { id: '42419', hash: '90a3c2cdbf9b391d9ed72c0639dc0786', version: require('./package.json').version, lang: 'en', deviceModel: os.type(), systemVersion: os.platform()+'/'+os.release() } // Connects to telegram function connect(){ client = telegramLink.createClient(app, telegramLink.PROD_PRIMARY_DC, function(){ if(!app.authKey){ log('Creating authkey...') client.createAuthKey(function(auth){ authKey = auth.key.encrypt('password') // I know sorry, but I'm testing. Will add security later, I promise // Writes the new encrypted key to disk fs.writeFile(keyPath,authKey,function(err){ if(err) log('Could not write key to disk:',err) else log('Done writing key to disk') }) log('Created key, writing it to disk') log('ready for phone number, use command: phone ') }) } else { log('Authkey loaded from disk. Should be ready to go.') log('Authkey:',app.authKey) whenReady() } }) client.once('dataCenter',function(dcs){ log('Datacenters:',dcs.toPrintable()) }) } // Download Contacts, ecc function whenReady(){ log('READY!') downloadData() } function downloadData(){ log('Downloading data...') client.contacts.getContacts('',function(cont){ contacts = cont log('\nContacts:\n',JSON.stringify(cont)+'\n') }) client.messages.getDialogs(0,-1,10,function(dialogs){ log('\nDialogs:\n',JSON.stringify(dialogs)+'\n') }) } var keyPath = cfgDir+'key' // Try loading key log('Checking disk for key...') fs.exists(keyPath,function(exists){ if(exists){ log('Key found') fs.readFile(keyPath,function(err,content){ if(err) log('Error while reading key:',err) else { authKey = telegramLink.retrieveAuthKey(content,'password') // yeah sorry just testing app.authKey = authKey log('Key loaded') } connect() }) } else { log('Key not found') connect() } })