تبلیغات اینستاگرام
ads.fileon.ir

ساخت ربات تلگرام با node js

نویسنده : محمد پارسایی | زمان انتشار : 01 اسفند 1398 ساعت 21:44

 

  1. پیش نیازها
  2. ثبت یک ربات تلگرام با استفاده از BotFather
  3. راه‌اندازی پروژه
  4. کدنویسی ربات خود
  5. گسترش ربات با استفاده از Now
  6. نتیجه گیری

مقدمه

گسترش بدون سرور، موضوع جذابی که توجه تعداد زیادی از تازه‌کارها و همچنین کهنه‌کاران در اکوسیستم فناوری را جلب می‌کند، بالاخره رسیده است. در این مقاله، ما یک رویکرد عملی به گسترش بدون سرور، که با نام FaaS (Function as a Server = تابع به عنوان یک سرور) شناخته می‌شود خواهیم داشت. معماری بدون سرور به زبان ساده راهی برای ساخت و اجرای برنامه‌ها و سرویس‌ها، بدون مدیریت سرور در زیرساخت است. و اما رویکرد عملی؟ ما یک ربات آب و هوای تلگرام با استفاده از Node.js خواهیم ساخت، که بر روی now میزبانی می‌شود.

ثبت یک ربات تلگرام با استفاده از BotFather

بله، درست حدث زدید! BotFather هم یک ربات است. قبل از این که به جزئیات کدنویسی ربات خود وارد شویم، نیاز خواهد بود که یک ربات را با استفاده از BotFather بسازیم و ثبت کنیم، تا یک کلید API‌ دریافت کنیم. ما به BotFather می‌رویم و قدم‌های زیر را دنبال می‌کنیم تا ربات خود را بسازیم.

راه‌اندازی پروژه

در شاخه‌ای به دلخواه خود، یک پوشه جدید بسازید که ربات ما را در خود خواهد داشت. در آن پوشه، ما پروژه خود را با اجرای npm init راه‌اندازی می‌کنیم، و مراحل را دنبال می‌کنیم تا برنامه خود را راه‌اندازی کنیم. در این شاخه، ما به دو فایل با نام‌های index.js که کد اصلی ما را شامل خواهد شد، و فایل .env که متغیرهای محیط ما را شامل خواهد شد نیاز خواهیم داشت.

ما باید چند پکیج را نصب کنیم، که در هنگام ساخت ربات آب و هوای ما به کمکمان خواهند آمد.

با نصب کردن تمام آن dependencyها، ما به openweathermap می‌رویم تا یک کلید API برای دسترسی به داده‌های آب و هوا داشته باشیم.

کدنویسی ربات خود

هر چقدر هم که ساخت یک ربات پیچیده به نظر برسد، ما در این آموزش یک ربات را با کمتر از ۱۰۰ خط کد خواهیم ساخت. بله، این کار ممکن است!

وارد کردن پکیج‌های خود

در بخش قبلی، ما چند پکیج نصب کردیم. ما به این صورت آن پکیج‌ها را در فایل index.js خود وارد خواهیم کرد:

var express = require("express");

var app = express();

var bodyParser = require("body-parser");

require("dotenv").config();

const axios = require("axios");`

app.use(bodyParser.json());

app.use(

  bodyParser.urlencoded({

    extended: true

  })

);

...

راه‌اندازی فایل .env

اکثر مردم استفاده ما از فایل env را تقبیح خواهند کرد؛ زیرا در حال حاضر در آن فایل ۳ متغیر داریم. اما ما نمی‌توانیم پیش بینی کنیم که ربات ما چقدر بزرگ خواهد بود. بهترین کار این است که آن متغیرها را به صورت جداگانه تعریف کنیم و وقتی که نیازشان داریم، به درستی به آن‌ها ارجاع کنیم. پس از این که کلید API و نشانه openweather و تلگرام خود را گرفتیم، آن‌ها را به این صورت در فایل .env اضافه خواهیم کرد:

OPENWEATHER_API_KEY = XXXXXXXXXXXXXXXXXXXXX

OPENWEATHER_API_URL = "http://api.openweathermap.org/data/2.5/weather?q="

TELEGRAM_API_TOKEN = XXXXXX:XXXXXXXXXXXXXXX

Keystrokeهای اصلی

پس از تعریف کردن متغیرهای محیط و وارد کردن پکیج‌های خود، به سراغ نوشتن منطق پایه ربات خود می‌رویم. ربات ما از سه متد اصلی استفاده خواهد کرد.

قبل از این که این متدها را کدنویسی کنیم، دو اندپویننت URL اصلی، اندپوینت API‌ تلگرام خود و اندپوینت openweathermap را تعریف می‌کنیم.

let telegram_url = "https://api.telegram.org/bot" + process.env.TELEGRAM_API_TOKEN +"/sendMessage";

let openWeatherUrl = process.env.OPENWEATHER_API_URL;

/start_bot اندپوینت برنامه ما است، که به API تلگرام ما قلاب خواهد شد. وقتی که ربات ما برای گسترش آماده است، درباره این مسئله صحبت خواهیم کرد.

app.post("/start_bot", function(req, res) {

const { message } = req.body;

let reply = "Welcome to telegram weather bot";

let city_check = message.text.toLowerCase().indexOf('/');

if(message.text.toLowerCase().indexOf("hi") !== -1){

    sendMessage(telegram_url,message,reply,res);

}else if( (message.text.toLowerCase().indexOf("check") !== -1) && (city_check !== -1 ) ){

    city = message.text.split('/')[1];

    get_forecast(city).then( response =>{

        post_forecast(telegram_url,response,message,res)

    });

}else{

    reply = "request not understood, please review and try again.";

    sendMessage(telegram_url,message,reply,res);

    return res.end();`

}

});

...

به طور شگفت‌انگیز، کل کدی که در ۱۸ خط ربات ما را تعریف می‌کند، همین است. این کد چگونه کار می‌کند؟

برای دریافت یک پیش‌بینی آب و هوا، تنها کاری که باید انجام دهیم این است که Check /Lagos را ارسال کنیم. سپس این کد مقدار ۲۳۲ درجه در Lagos را باز خواهد گرداند. پس این کد به دنبال یک کلمه کلیدی به نام Check می‌گردد و شهر را که پس از «/» آورده شده است، به دست می‌آورد.

تعریف این ۱۸ خط

در چهار خط اول، ما بدنه درخواست خود را parse می‌کنیم و آن را داخل یک آبجکت پیام ذخیره می‌کنیم. سپس ما پیام خوش‌آمدگویی داخل متغیر reply (پاسخ) خود را راه‌اندازی می‌کنیم و بررسی می‌کنیم که آیا متن دریافت شده از طرف کاربر یک اسلش را در خود دارد یا نه. چهار خط بعدی، سه شرط هستند. شرط اول بررسی می‌کند که آیا پیام یک «Hi» یا «hi» ساده است یا نه؛ اگر اینطور است، متد sendMessage(); فراخوانی می‌شود. این متد چهار پارامتر را می‌پذیرد که می‌توانید در کد بالا ببینید. دومین شرط بررسی می‌کند که آیا پیام دریافتی کلمه کلیدی «Check» و همچنین یک شهر را در خود دارد یا نه. اگر این شرط به صورت صحیح ارزیابی شود، متد get_forecast(); را فراخوانی می‌کند که یک پاسخ را بر می‌گرداند. این پاسخ یک promise است که ما به متد post_forecast(); منتقل می‌کنیم. این متد، چیزی است که با وضعیت آب و هوایی فعلی به کاربر پاسخ می‌دهد.

حال ادامه می‌دهیم و سه متدی که به آن‌ها اشاره شد را به همراه جزئیات مطرح می‌کنیم:

متغیر resp شامل یک پیام قالب‌بندی شده، برای ارسال به کاربر است.

بله، ما فراموش نکردیم که برنامه‌مان بر روی پورت ۳۰۰۰ قرار خواهد داشت:

function sendMessage(url, message,reply,res){

axios.post(url, {`chat_id: message.chat.id,`

    text: reply

}).then(response => {

    console.log("Message posted");

    res.end("ok");

}).catch(error =>{

    console.log(error);

});

}

...

function get_forecast(city){

    let new_url = openWeatherUrl + city+"&appid="+process.env.OPENWEATHER_API_KEY;

    return axios.get(new_url).then(response => {

        let temp = response.data.main.temp;

        //دما را از کلوین به سلسیوس تبدیل می‌کند

        temp = Math.round(temp - 273.15); 

        let city_name = response.data.name;

        let resp = "It's "+temp+" degrees in "+city_name;

        return resp;

    }).catch(error => {

        console.log(error);`

    });

}

...

گسترش ربات با استفاده از Now

ربات‌های تلگرام با پیروی از یک عنوان یک قانون اصلی بر روی SSL گسترش داده می‌شوند، که now آن را برای ما فراهم می‌کند. Now یک پلتفرم است که شما را قادر می‌سازد تا برنامه‌های node خود را به راحتی میزبانی کنید. حال ما یک پکیج را به عنوان پکیج آخر در پروژه خود نصب خواهیم کرد.

npm install -g now - این دستور پکیج now را نصب خواهد کرد. وقتی که فرایند نصب به پایان رسیده است، می‌توانیم فقط با نوشتن now در ترمینال خود، برنامه خود را به فضای ابری ببریم. در هنگام اتمام نصب، یک URL برای ما فراهم خواهد شد که برای ساخت webhook خود با استفاده از cURL، به این صورت استفاده خواهد شد:

curl -F "url=https://URL_FROM_NOW/start_bot" https://api.telegram.org/botYOUR_TELEGRAM_API_TOKEN/setWebhook

اگر این عملیات با موفقیت به پایان برسد، باید این پاسخ JSON را دریافت کنید:

{

    "ok":true,

    "result":true,

    "description":"Webhook was set"

}

نتیجه گیری

در این آموزش، ما یک ربات تلگرام با استفاده از Node.js ساختیم و همچنین با استفاده از now، با گسترش بدون سرور آشنا شدیم.

ارتقاهای جالبی می‌توانند به این ربات اعمال شوند. آیا حس ماجراجویی دارید؟ پروژه را از گیت‌هاب بردارید و بر روی آن کار کنید.

منبع