เบเบฒเบ™เป€เบ›เบตเบ”เปƒเบŠเป‰เบ‡เบฒเบ™เบ—เบฒเบ‡เป„เบเบ‚เบญเบ‡เบชเบฐเบ„เบฃเบดเบš Mikrotik เบˆเบฒเบ Telegram v 2.0

ะ’ัะตั… ั ะฟั€ะพัˆะตะดัˆะธะผ ะฟั€ะฐะทะดะฝะธะบะพะผ. ะ”ะฐะฝะฝะฐั ั‚ะตะผะฐ ัะฒะปัะตั‚ัั ะฑะพะปะตะต ะปัƒั‡ัˆะตะน ะฒะตั€ัะธะตะน ั‚ะพะณะพ, ั‡ั‚ะพ ั ะฟะธัะฐะป ะฒ ะดะฐะปะตะบะพะผ 2016 ั‚ัƒั‚.

ะ’ ั†ะตะปะพะผ ะฟั€ะธะฝั†ะธะฟ ั€ะฐะฑะพั‚ั‹ ะฝะต ะธะทะผะตะฝะธะปัั, ั ั‚ะพะน ะปะธัˆัŒ ั€ะฐะทะฝะธั†ะตะน, ั‡ั‚ะพ ั‚ะตะฟะตั€ัŒ ะพะฝ ะพั‚ั€ะฐะฑะฐั‚ั‹ะฒะฐะตั‚ ะผะณะฝะพะฒะตะฝะฝะพ ะฑะตะท ะทะฐะดะตั€ะถะตะบ.

ะ—ะฐะบะธะดั‹ะฒะฐะตะผ ัะบั€ะธะฟั‚ ะฒ Mikrotik, ะผะตะฝัะตะผ BotID ะธ ChatID ะฝะฐ ัะฒะพะธ ะธ ัะพะทะดะฐะตะผ ะฝะฐ ะฝะตะณะพ schedule. ะกั‚ะฐะฒะธะผ ะฟะฐั€ะฐะผะตั‚ั€ ยซStart Timeยป ะฝะฐ startup (ะ—ะฐะฟัƒัะบ ัะบั€ะธะฟั‚ะฐ ะฟั€ะธ ัั‚ะฐั€ั‚ะต.)
ยซIntervalยป: 00:00:00
ะ’ ะพัั‚ะฐะปัŒะฝะพะผ ะฒัะต ะบะฐะบ ะธ ะฑั‹ะปะพ.

Telegram-v2

:delay 10
:global mtIdentity [/system identity get name];
:global botID "botXXXXXXXXX:XXXXXXXXXXXXXXXXXXXXXXXXX" ;
:global myChatID "YYYYYY" ;
:local chatId 0;
:local messageId 0;


:local parse do={
  :local startLoc ([:find $content $variable -1] + [:len $variable] + 2);
  :local commaLoc ([:find $content "," $startLoc] - 1 + 1);
  :local braceLoc ([:find $content "}" $startLoc] - 1 + 1);
  :local endLoc $commaLoc;
  :local startSymbol [:pick $content $startLoc]
  :if ($braceLoc != 0 and ($commaLoc = 0 or $braceLoc < $commaLoc)) do={
    :set endLoc $braceLoc;
  };
  :if ($startSymbol = "{") do={
    :set endLoc ($braceLoc + 1);
  };
  :if ($quotas = true) do={
    :set startLoc ($startLoc + 1);
    :set endLoc ($endLoc - 1);
  }
  :if ($endLoc < $startLoc) do={
    :set endLoc ($startLoc + 1);
  };
  :local message [:pick $content $startLoc $endLoc]
  #:log info $message;
  :return $message;
}


:while ( true ) do={
  :do {
    #:log info "https://api.telegram.org/$botID/getUpdates?offset=$messageId&limit=1&allowed_updates=message&timeout=60";
    :tool fetch url=("https://api.telegram.org/$botID/getUpdates?offset=$messageId&limit=1&allowed_updates=message&timeout=60") dst-path="getUpdates";
    :local content [/file get [/file find name=getUpdates] contents] ;
    #:log info $content;
    :if ([:len $content] > 30) do={
      :set messageId ([$parse content=$content variable="update_id"] + 1)
      :local message [$parse content=$content variable="text" quotas=true]
      :local chat [$parse content=$content variable="chat"]
      :local chatId [$parse content=$chat variable="id"]      
      
      :if (($chatId = $myChatID) and ([/system script find name=$message] != "")) do={
        :system script run $message;
      } else={
        :tool fetch url=("https://api.telegram.org/$botID/sendmessage?chat_id=$chatId&text=$mtIdentity: Unknown command: $message") keep-result=no
      }
    }
  } on-error={}
};

ะ—ะฐ ะฟะฐั€ัƒ ะปะตั‚ ะฟะพะปัŒะทะพะฒะฐะฝะธั ะฑั‹ะป ะฒั‹ัะฒะปะตะฝ ะฑะฐะณ, ะฟะพ ะฝะตะฟะพะฝัั‚ะฝั‹ะผ ะฟั€ะธั‡ะธะฝะฐะผ ัะปะฐะฑะตะฝัŒะบะธะต Mikrotik ะฟะพั‡ะตะผัƒ ั‚ะพ ะพัั‚ะฐะฝะฐะฒะปะธะฒะฐัŽั‚ ัะบั€ะธะฟั‚, ะฝะฐ ะฑะพะปะตะต ะผะพั‰ะฝั‹ั… ั€ะฐะฑะพั‚ะฐะตั‚ ะฑะตะท ะพัั‚ะฐะฝะพะฒะพะบ.

ะ”ะปั ัั‚ะธั… ั†ะตะปะตะน ะฝะฐะบะธะดะฐะป ะบะพัั‚ั‹ะปัŒ WatchDog. ั‚ัƒั‚ ะผะตะฝัะตะผ ะธะผั ัะบั€ะธะฟั‚ะฐ ะฝะฐ ั‚ะพ ะบะฐะบะพะต ัƒะบะฐะทั‹ะฒะฐะปะธ ะฒั‹ัˆะต. ะธ ัั‚ะฐะฒะธะผ ะธะฝั‚ะตั€ะฒะฐะป ะฟะตั€ะตะทะฐะฟัƒัะบะฐ 5 ะผะธะฝัƒั‚. ะšะฐะถะดั‹ะต 5 ะผะธะฝัƒั‚ ะฝะฐัˆะฐ ยซัะผะพั‚ั€ัั‰ะฐั ัะพะฑะฐะบะฐยป ะฑัƒะดะตั‚ ะฟั€ะพะฒะตั€ัั‚ัŒ ัะบั€ะธะฟั‚, ะธ ะตัะปะธ ะพะฝ ะฝะต ั€ะฐะฑะพั‚ะฐะตั‚, ั‚ะพ ะทะฐะฟัƒัั‚ะธั‚ ะตะณะพ.

WatchDogT.me

:global scriptname "t.me"
:if ([:len [/system script job find script=$"scriptname"]] > 0) do={
:log info "$scriptname Already Running - killing old script before continuing"
:foreach counter in=[/system script job find script=$"scriptname"] do={
/system script job remove $counter
}
}
/system script run $scriptname

ะัƒ ะธ ะฝะฐ ะดะตัะตั€ั‚, ัะบั€ะธะฟั‚ ะฒะทัั‚ ั ั„ะพั€ัƒะผะฐ Mikrotik.
ะžั‚ะฟั€ะฐะฒะปัะตั‚ ะฒะฐะถะฝั‹ะต ั‚ะพะฟะธะบะธ ะธะท ะปะพะณะฐ ะฝะฐะผ ะฒ ั‚ะตะปะตะณัƒ.

ะ—ะฐะบะธะดั‹ะฒะฐะตะผ ัะบั€ะธะฟั‚ ะฒ schedule ะธ ัƒะบะฐะทั‹ะฒะฐะตะผ ะธะฝั‚ะตั€ะฒะฐะป ะฟะตั€ะตะทะฐะฟัƒัะบะฐ ะบะฐะถะดั‹ะต 5 ะผะธะฝัƒั‚, ะผะตะฝัะตะผ BotID ะธ ChatID ะฝะฐ ัะฒะพะธ.

Notify-log

:global lastTime
:global output
:global mtIdentity [/system identity get name];
:global botID "botXXXXXXXXX:XXXXXXXXXXXXXXXXXXXXXXXXX" ;
:global myChatID "YYYYYY" ;

:local LogGet [ :toarray [ /log find topics~"critical" || message~"login failure" || message~"[Ff]ailure" ] ] ;
:local LogtLineCount [ :len $LogGet ] ;
if ($LogtLineCount > 0) do={
   :local currentTime "$[ /log get [ :pick $LogGet ($LogtLineCount -1) ] time ]";
   :if ([:len $currentTime] = 10 ) do={
      :set currentTime [ :pick $currentTime 0 10 ];
   }
   :set output "$currentTime - $[/log get [ :pick $LogGet ($LogtLineCount-1) ] message ]";
   :if (([:len $lastTime] < 1) || (([:len $lastTime] > 0) && ($lastTime != $currentTime))) do={
      :set lastTime $currentTime ;
         :tool fetch url=("https://api.telegram.org/$botID/sendmessage?chat_id=$myChatID&text="$mtIdentity" :  $output") keep-result=no
   }
}

ะŸะพะปัƒั‡ะธะผ ั€ะตะทัƒะปัŒั‚ะฐั‚:

เบเบฒเบ™เป€เบ›เบตเบ”เปƒเบŠเป‰เบ‡เบฒเบ™เบ—เบฒเบ‡เป„เบเบ‚เบญเบ‡เบชเบฐเบ„เบฃเบดเบš Mikrotik เบˆเบฒเบ Telegram v 2.0

เปเบซเบผเปˆเบ‡เบ‚เปเป‰เบกเบนเบ™: www.habr.com

เป€เบžเบตเปˆเบกเบ„เบงเบฒเบกเบ„เบดเบ”เป€เบซเบฑเบ™