اینترنت اشیاء, پروژه, پروژه آردوینو, توصیه شده

اینترنت اشیاء و اتصال به ربات تلگرام بدون محدودیت و فیلتر

چند سالی می‌شود که تلگرام و کلیه متعلقاتش فیلتر شده است و دوجین نرم افزارهای پیام‌رسان داخلی جهت جایگزینی معرفی شده‌اند. اما همچنان کاربرهای ایرانی با توجه به آمار رسمی منتشر شده و همچنین میزان دانلود پیام‌رسان‌های داخلی، تمایلی به استفاده از نرم افزارهای پیام رسان داخلی نشان نمی‌دهند و به کمک انواع و اقسام فیلترشکن‌ها سعی می‌کنند که دسترسی خود را به تلگرام حفظ کنند. از طرفی با رشد روز افزون دستگاه‌های IOT و کاربردی شدن آنها نیاز بستر تعاملی ساده با این دستگاه‌ها بیش از پیش حس می‌شود! و چه بستری مناسب‌تر و در دسترس تر از پیام‌رسان! با جزییات بیشتر این اتصال هیجان انگیز به ربات تلگرام بدون فیلتر با سیسوگ همراه باشید:)

 

چرا و چطور پیام رسان تلگرام

علامت تلگرام

همان‌طور که در مقدمه اشاره کردم همچنان پیام‌رسان تلگرام جزو پر استفاده ترین پیام‌رسان‌ها بین کاربران ایرانی است. پس اگر قرار باشد پیام‌رسانی را برای این اتصال (اتصال دستگاه‌های IOT و پیام‌رسان) انتخاب کنیم بهترین گزینه همچنان با اختلاف زیاد تلگرام است. تا قبل از فیلترینگ رسمی تلگرام در کشور در چند مقاله (آموزش اتصال ربات تلگرام به آردوینو – قسمت اول و آموزش اتصال ربات تلگرام به آردوینو – قسمت دوم) سعی کردیم نحوه اتصال دستگاه‌های IOT را با این پیام‌رسان آموزش دهیم و در ادامه طی “پروژه آموزش اتصال ربات تلگرام به آردوینو ESP8266 – ربات تلگرام در خانه” با ذکر یک مثل عملی جهت خاموش و روشن کردن لامپ‌های یک خانه نمونه کاربردی آن را بررسی کردیم.

اما با فیلتر شدن تلگرام ورق برگشت! هرچند که تلگرام از انواع مختلف پراکسی پشتیبانی می‌کند، اما پیاده سازی آنها در دستگاه‌هایی که مقدار حافظه RAM و قدرت پردازشی محدودی دارند کاری ست بس دشوار! (البته که نشدنی نیست و پروتکل‌های سبک مثل socks و http را به راحتی می‌توان پیاده سازی کرد.) برای همین سعی کردیم که یک راه حل ساده و البته ارزان را در این مقاله بررسی کنیم که در ادامه بیشتر آن را توضیح خواهیم داد.

 

چرا از پروتکل های استاندارد استفاده نکنیم ؟

VPN

همانطور که احتمالا میدانید پروتکل های متنوعی وجود دارند که میتوان از آنها برای دسترسی به یک سرور (مثلا تلگرام) استفاده کرد. پروتکل های سبک و سنگینی که پیاده سازی آن در سخت افزار گاهی نشدنی و در مواردی هم بسیار دشوار است. اما چیزی که ممکن است ندانید این است که برخی از این پروتکل‌ها تنها در داخل ایران قابل دسترسی دارند به عنوان نمونه پروتکل VPN برای ارتباط داخل به خارج از ایران مسدود است (البته اینجا منظور خود VPN است نه انواع رمزگذاری شده آن) یا پروتکل SOCKS هم چنین شرایطی دارد. پس اگر آنها را حتی در سخت افزار پیاده سازی کنیم با چالش دیگری روبرو خواهیم بود و آن هم امکان دسترسی است.

البته کار نشد ندارد. مثلاً برای ایجاد دسترسی SOCKS ابتدا باید یک سرور داخلی داشته باشید که دستگاه‌های شما از طریق SOCKS با این سرور در ارتباط باشند (قبلاً گفتیم این پروتکل‌ها در شبکه داخل ایران همچنان کار می‌کنند) بعد سرور شما با یکی از پروتکل‌های رمز شده ارتباط با خارج از ایران داشته باشد و بدین طریق قادر خواهید بود که دستگاه IOT خود را به ربات تلگرام متصل کنید. اما این راه فارغ از چالش‌های فنی که ممکن است ایجاد کند هزینه زیادی در بر خواهد داشت که شاید برای خیلی کسب و کارها انجام این هزینه منطقی نباشد.

 

ایده اولیه راه حل اتصال به سرور تلگرام

با توجه به استدلال قبل، راه حل مورد نظر نباید هزینه زیادی داشته باشد و تا جای ممکن باید ساده باشد تا بتوان به آن را بر روی پلتفرم‌های IOT پیاده سازی کرد! اما چطور چنین چیزی ممکن می‌شود؟ خوب مسئله زیاد پیچیده‌ای نیست.

یک مدل حمله و اسنیف اطلاعات وجود دارد به اسم Man-in-the-middle! نحوه کار به این شکل است که هکر بین فرستنده و گیرنده قرار می‌گیرد و ترافیک را رصد می‌کند! ما در اینجا نمی‌خواهیم ترافیک خودمان را رصد کنیم، بلکه می‌خواهیم از داخل ایران به خارج از ایران منتقل کنیم. پس از همین الگو استفاده خواهیم کرد. یعنی یک نرم افزاری خواهیم داشت که بین دستگاه‌های اینترنت اشیاء (IOT) و سرور تلگرام قرار خواهد گرفت و کارش این است که اطلاعات را از دستگاه دریافت کند به سرور تلگرام ارسال کند، سپس جواب را از سرور تلگرام دریافت کرده و بدون فیلتر به برنامه ربات تلگرام در دستگاه برساند.

حالا که کلیت موضوع و راه مشخص شد، انتخاب پلتفرم مناسب باقی می‌ماند، این برنامه واسط را با هر زبانی می‌شود نوشت، اما ارزان بستری که می‌شود پیدا کرد بسترهاست اشتراکی و زبان PHP است. هزینه سالیانه تهیه یک‌هاست اشتراکی در مثلاً آلمان حدود ۲۵ هزار تومان یا حتی کمتر از این مقدار است و دامنه هم حدود ۱۵ تومان برای ۳ سال است. واقعاً چه چیزی کم هزینه‌تر از این می‌توان پیدا کرد؟

 

تغییرات لازم در کتابخانه ZeusTg

قبلاً در “پروژه آموزش اتصال ربات تلگرام به آردوینو ESP8266 – ربات تلگرام در خانه” کتابخانه ZeusTg را از صفر نوشتیم و سورس آن را می‌توانید از طریق گیت هاب سیسوگ پیدا کنید. در این کتابخانه از SOCKET برای اتصال به سرور استفاده می‌کنیم. لازم است که مکانیسم سوکت را به وب کلاینت تغییر دهیم تا قادر باشیم درخواست‌ها را از طریق متدهای POST و GET به سرور ارسال کنیم.

خوشبختانه برای این کار نیاز نبود تا کل کتابخانه را از اول بازنویسی کنیم. تنها تغییرات کوچکی لازم بود تا در فانکشن SendCommand اعمال بشود:

 

البته فانکشنی هم برای تنظیم کردن آدرس پراکسی به کتابخانه اضافه شده است که تنها لازم است آدرس پراکسی را در آن تنظیم کنیم و دیگر تمام! همه چیز به خوبی کار خواهد کرد.

 

دانلود و راه اندازی کد آردوینو ESP8266

فایل پروژه در انتهای پست پیوست شده است و شما می‌توانید به‌صورت رایگان آن را دانلود کنید. کدها درون نرم افزار VSCODE و با استفاده از افزونه platformIO نوشته شده‌اند. با توجه به اینکه هنوز IDE حرفه‌ای تر و رسمی آردوینو منتشر نشده است، بهتر است به جای نرم افزار فعلی آردوینو، از platformIO استفاده کنید. آموزش پلت فرم آی او قبلاً در سیسوگ منتشر شده است. همچنین شما می‌توانید کد برنامه را بدون هیچ مشکلی درون نرم افزار خود آردوینو باز کنید. به یاد داشته باشید که درون کد، حتماً مقادیر زیر را با اطلاعات مربوط به خود تکمیل کنید:

 

راه اندازی پراکسی سمت سرور

برای خریدهاست حتماً باید دقت داشته باشید که هاست ایران خریداری نکنید و حتماً هاست خارج از ایران باشد. همچنین قادر به پشتیبانی PHP نیز باشد. تنظیم دامنه نیز معمولاً توسط خود شرکت‌های هاستینگ انجام می‌شود. تنها کافی است که یک فایل با اسم دلخواه درون‌هاست خود ایجاد کنید و محتوای زیر را درون آن قرار دهید:

برای اطمینان از این که تمام کارها را به درستی انجام داده‌اید، اگر آدرس فایل را در مرورگر وارد کنید باید با صفحه‌ای به شکل زیر مواجه شوید.

 

اگر نوشته بالا رو دیدید، یعنی همه چیز آماده تست است و ربات تلگرام شما می‌تواند بدون فیلتر کار کند.

ممکن است این سؤال برایتان پیش آمده باشد که آدرس صفحه را چگونه به دست بیاورید؟ فرض کنید نام دامنه شما example.ir باشد و فایل را با اسم xbot.php در سرور ذخیره کرده باشید. بدیهی است که آدرس فایل به شکل زیر خواهد بود.

 

و به شکل زیر باید در تابع SetProxyHost استفاده شود:

 

شما با استفاده از این کتابخانه و برنامه می‌توانید طیف وسیعی از دستگاه‌های اینترنت اشیاء IOT را بدون فیلتر به ربات پیام رسان تلگرام متصل کنید و این که چه وسیله‌ای را به چه شکلی متصل کنید، برمی گردد به میزان خلاقیت شما در استفاده از این کتابخانه. از درب ورودی منزل یا کرکره برقی مغازه و پارکینگ تا سیستم‌های حضور و غیاب … همه و همه قادر هستند از این کتابخانه استفاده کنند.

 

 

فیلم عملکرد مدار

انتشار مطالب با ذکر نام و آدرس وب سایت سیسوگ، بلامانع است.

شما نیز میتوانید یکی از نویسندگان سیسوگ باشید.   همکاری با سیسوگ

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

6 دیدگاه در “اینترنت اشیاء و اتصال به ربات تلگرام بدون محدودیت و فیلتر

  1. محمد گفت:

    درود
    اگر واسه ارتباط iot بجای استفاده از ربات تلگرام تو یه پروژه از mqtt استفاده بشه چه تفاوت هایی خواهد داشت ؟
    یعنی تفاوت استفاده از ربات تلگرام و mqtt چی هستش؟

    1. زئوس Zeus زئوس Zeus گفت:

      mqtt یکی از پروتکل هایی هست که الانم زیاد داره استفاده میشه
      اما شما برای mqtt لازمه که احتمالا برنامه اختصاصی خودتون رو بنوسید ولی استفاده از ربات توی یک پیام رسان خیلی کار رو از بابت دم دست بودن راحت میکنه – اگر نه mqtt اصلا برای این منظور طراحی شده و قبلا توی سیسوگ در موردش مقاله هم نوشتیم توی سایت
      خیلی هم سبک تره

      1. محمد گفت:

        خب درسته ارتباط با تلگرام آسونتره نسبت به mqtt ولی الان با توجه به فیلتر بودن تلگرام و استفاده از هاست اختصاصی به عنوان یه روش برای دور زدن فیلتر که باز دردسر و هزینه خودش رو داره بهترین راه همون mqtt و یه بروکر مثل hivemq واسه یه ارتباط iot هستش

        1. زئوس Zeus زئوس Zeus گفت:

          خوب البته که اگر بتونید یه نرم افزار اندورید اختصاصی با نیاز خودتون پیاده سازی کنید (که البته هزینه اش کم هم نیست) قطعا پروتکل های سبک مثل mqtt و امثالهم بهترین انتخاب هستن !
          البته اگر بخواید حرفه ای کار کنید نباید سراغ بروکر های رایگان بردید و بهتره که بروکر خودتون رو راه اندازی کنید !

  2. زئوس جان راجب امنیت backend این پروژه هم یه بحثی میکنید؟ مثلا حملات DDoS روی سرور یا اسنیف کردن اطلاعات

    1. زئوس Zeus زئوس Zeus گفت:

      سلام به نکته خیلی خوبی اشاره کردید- لازمه اشاره کنم که این یه مثال خیلی ساده است نکات امنیتی توش دیده نشده ولی کارهایی که میشه کرد برای امنیت زیادن مثلا انکریپت کرد اطلاعات ارسالی رو با یه الگرویتم امن نظیر aes
      یا مثلا اضافه کردن یک فیلد توی پست دیتا ها که هر درخواست دهنده ای نتونه از سرویس شما استفاده کنه و امثالهم ….