Дистанционно Π°ΠΊΡ‚ΠΈΠ²ΠΈΡ€Π°Π½Π΅ Π½Π° скриптовС Π½Π° Mikrotik ΠΎΡ‚ Telegram v 2.0

Всички с изминалия ΠΏΡ€Π°Π·Π½ΠΈΠΊ. Π’Π°Π·ΠΈ Ρ‚Π΅ΠΌΠ° Π΅ ΠΏΠΎ-Π΄ΠΎΠ±Ρ€Π° вСрсия Π½Π° Ρ‚ΠΎΠ²Π°, ΠΊΠΎΠ΅Ρ‚ΠΎ написах ΠΏΡ€Π΅Π· 2016 Π³. Ρ‚ΡƒΠΊ.

ΠšΠ°Ρ‚ΠΎ цяло ΠΏΡ€ΠΈΠ½Ρ†ΠΈΠΏΡŠΡ‚ Π½Π° Ρ€Π°Π±ΠΎΡ‚Π° Π½Π΅ сС Π΅ ΠΏΡ€ΠΎΠΌΠ΅Π½ΠΈΠ», с СдинствСната Ρ€Π°Π·Π»ΠΈΠΊΠ°, Ρ‡Π΅ сСга Ρ€Π°Π±ΠΎΡ‚ΠΈ Π½Π΅Π·Π°Π±Π°Π²Π½ΠΎ Π±Π΅Π· забавянС.

ΠšΠ°Ρ‡Π²Π°ΠΌΠ΅ скрипта Π² Mikrotik, промСнямС BotID ΠΈ ChatID Π½Π° наши ΠΈ създавамС Π³Ρ€Π°Ρ„ΠΈΠΊ Π·Π° Π½Π΅Π³ΠΎ. Π—Π°Π΄Π°ΠΉΡ‚Π΅ ΠΏΠ°Ρ€Π°ΠΌΠ΅Ρ‚ΡŠΡ€Π° "НачалСн час" Π½Π° стартиранС (Π‘Ρ‚Π°Ρ€Ρ‚ΠΈΡ€Π°ΠΉΡ‚Π΅ скрипта ΠΏΡ€ΠΈ стартиранС.)
Π˜Π½Ρ‚Π΅Ρ€Π²Π°Π»: 00:00:00
Всичко Π΄Ρ€ΡƒΠ³ΠΎ Π΅ ΠΊΠ°ΠΊΡ‚ΠΎ си бСшС.

Π’Π΅Π»Π΅Π³Ρ€Π°ΠΌΠ°-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.
Π˜Π·ΠΏΡ€Π°Ρ‰Π° Π²Π°ΠΆΠ½ΠΈ Ρ‚Π΅ΠΌΠΈ ΠΎΡ‚ Π΄Π½Π΅Π²Π½ΠΈΠΊΠ° Π² Π½Π°ΡˆΠ°Ρ‚Π° ΠΊΠΎΠ»ΠΈΡ‡ΠΊΠ°.

Π’ΠΊΠ°Ρ€Π°ΠΉΡ‚Π΅ скрипта Π² Π³Ρ€Π°Ρ„ΠΈΠΊΠ° ΠΈ посочСтС ΠΈΠ½Ρ‚Π΅Ρ€Π²Π°Π»Π° Π·Π° рСстартиранС Π½Π° всСки 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

ДобавянС Π½Π° Π½ΠΎΠ² ΠΊΠΎΠΌΠ΅Π½Ρ‚Π°Ρ€