Merge branch 'reFactor' of TelegramBots/BobbyIPTV_Suzie into master
This commit is contained in:
		
						commit
						b19b8ff70c
					
				
							
								
								
									
										407
									
								
								app.js
									
									
									
									
									
								
							
							
						
						
									
										407
									
								
								app.js
									
									
									
									
									
								
							| @ -1,31 +1,9 @@ | ||||
| require('dotenv').config(); | ||||
| 
 | ||||
| var request = require("request"); | ||||
| var throttledRequest = require('throttled-request')(request); | ||||
| throttledRequest.configure({ requests: 8, milliseconds: 60000 }); //send 1 request per second
 | ||||
| cachedRequest = require('cached-request')(throttledRequest); | ||||
| cachedRequest.setCacheDirectory("./cache"); | ||||
| 
 | ||||
| const fs = require('fs'); | ||||
| 
 | ||||
| const logger = require('perfect-logger'); | ||||
| const TelegramBot = require('node-telegram-bot-api'); | ||||
| 
 | ||||
| const bot_chat = require('./data/bot/chat') | ||||
| const bot_welcome = require('./data/bot/welcomeMesage') | ||||
| const bot_questions = require('./data/bot/questions') | ||||
| const bot_football = require('./data/bot/requests/football') | ||||
| const bot_joke = require('./data/bot/requests/joke') | ||||
| const bot_faq_subscription = require('./data/bot/faq/subscriptions') | ||||
| const bot_subStatus = require('./data/bot/requests/updateSubStatus') | ||||
| const bot_faq_whatAppToUse = require('./data/bot/faq/whatAppToUse') | ||||
| 
 | ||||
| 
 | ||||
| const token = process.env.BOT_TOKEN; | ||||
| const name = process.env.BOT_NAME; | ||||
| const channel = process.env.CHANNEL | ||||
| const admins = JSON.parse(process.env.ADMIN_ID) | ||||
| let comp_users = [] | ||||
| 
 | ||||
| // Configure Settings
 | ||||
| logger.initialize(name + "_bot", { | ||||
| @ -35,370 +13,63 @@ logger.initialize(name + "_bot", { | ||||
|   // customBannerHeaders: 'This is a custom banner'  // Custom Log Banner
 | ||||
| }); | ||||
| 
 | ||||
| const bot = new TelegramBot(token, { | ||||
|     polling: true | ||||
| }); | ||||
| const TelegramBot = require('node-telegram-bot-api'); | ||||
| 
 | ||||
| const common = require('./data/bot/lib/common') | ||||
| const questions = require('./data/bot/lib/questions') | ||||
| const requests = require('./data/bot/lib/requests') | ||||
| const bot_welcome = require('./data/bot/functions/welcomeMesage') | ||||
| const bot_faq_whatAppToUse = require('./data/bot/functions/faq/whatAppToUse') | ||||
| const bot_faq_subscription = require('./data/bot/functions/faq/subscriptions') | ||||
| const bot_subStatus = require('./data/bot/functions/requests/updateSubStatus') | ||||
| 
 | ||||
| 
 | ||||
| let commands = require('./data/group/commands') | ||||
| let navigation = require('./data/group/FAQ') | ||||
| let chat = require('./data/group/chat') | ||||
| let jointArray = navigation.concat(chat) | ||||
| 
 | ||||
| 
 | ||||
| const bot = new TelegramBot(token, { polling: true }); | ||||
| 
 | ||||
| // Wlecome Message
 | ||||
| bot.on('new_chat_members', (msg) => { | ||||
|   bot_welcome.welcomeMessage(bot, msg, logger) | ||||
| }); | ||||
| 
 | ||||
| bot.on('message', (msg) => { | ||||
|     // Listen call for "help"
 | ||||
|     bot_chat.help(bot, msg, logger) | ||||
|     // listen for "filelinked code"
 | ||||
|     bot_chat.filelinked_help(bot, msg, logger) | ||||
|     // listen for "bye"
 | ||||
|     bot_chat.bye(bot, msg, logger) | ||||
|     // listen for "thank you BOT"
 | ||||
|     bot_chat.thankYou(bot, msg, logger, name) | ||||
|     // listen for "i love you BOT"
 | ||||
|     bot_chat.iLoveYou(bot, msg, logger, name) | ||||
|     // listen for "deal"
 | ||||
|     bot_chat.loveADeal(bot, msg, logger) | ||||
|     // listen for "football today"
 | ||||
|     bot_football.gamesToday(bot, msg, logger) | ||||
|     // listen for "BOT tell me a joke"
 | ||||
|     bot_joke.tellMe(bot, msg, logger, name) | ||||
|     // listen for "you there BOT"
 | ||||
|     bot_chat.youThere(bot, msg, logger, name) | ||||
|     // listen for "fuck off BOT"
 | ||||
|     bot_chat.fOff(bot, msg, logger, name) | ||||
|     // listen for "what sub should i buy?"
 | ||||
|     bot_questions.whatSubShouldIBuy(bot, msg, logger) | ||||
|     // listen for "sub status"
 | ||||
|     bot_questions.subStatus(bot, msg, logger) | ||||
|     // listen for "set sub X to X"
 | ||||
|   bot_subStatus.setSubStatus(bot, msg, logger) | ||||
| 
 | ||||
|   if (msg.text && msg.text.toString().includes("/sub_status")) { | ||||
|     questions.subStatus(bot, msg, logger) | ||||
|   } | ||||
| 
 | ||||
|   if (msg.text && msg.text.toString().includes("/football_today")) { | ||||
|     requests.football_today(bot, msg, logger) | ||||
|   } | ||||
| 
 | ||||
|   if (msg.text && msg.text.toString().includes("/joke")) { | ||||
|     requests.joke(bot, msg, logger) | ||||
|   } | ||||
| 
 | ||||
|   if (msg.text && msg.text.toString() === "- What app should I use?") { | ||||
|     bot_faq_whatAppToUse.main(bot, msg, logger) | ||||
|   } | ||||
|   bot_faq_whatAppToUse.appSwitch(bot, msg, logger) | ||||
| 
 | ||||
| 
 | ||||
|     // FAQ susbcription prices
 | ||||
|   if (msg.text && msg.text.toString() === "- Subscription Options") { | ||||
|     bot_faq_subscription.pricesImageList(bot, msg, logger) | ||||
| 
 | ||||
|     const howToSignUp = "- how to get a subscription?"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === howToSignUp) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked how to get a subscription"); | ||||
|         bot.sendMessage(msg.chat.id, "To purchase a subscription you need to send a DM Sarah (@bob_15).") | ||||
|             .then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, "PLEASE BE PATIENT AND WAIT FOR HER TO GET BACK TO YOU.").then(() => { | ||||
|                     return bot.sendMessage(msg.chat.id, ` | ||||
|                     When you DM Sarah to purchase the subscription please let her know: | ||||
|                      | ||||
| 1. What device the sub is going onto | ||||
| 2. If there's a specific username you would like and | ||||
| 3. If you don't want adult channels included. If you don't want adult channels and don't mention it when purchasing Your sub WILL be issued WITH adult channels. These can't be removed. | ||||
|                     `)
 | ||||
|                 }) | ||||
|             }) | ||||
|   } | ||||
| 
 | ||||
|     const suburls = "- subscription urls"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === suburls) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked about subscription urls"); | ||||
|         bot.sendMessage(msg.chat.id, "In this IPTV room we don't give out sub URLs or m3us. We have dedicated apps to play all subs on your Android box or IPTV player in our FileLinked."); | ||||
|     } | ||||
| 
 | ||||
|     const multipleDevices = "- can i stream on multiple devices?"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === multipleDevices) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked if they could stream multiple devices"); | ||||
|         bot.sendMessage(msg.chat.id, "No. All subs sold is this room are one connection subs unless otherwise stated.\n\nThis means that you can have your sub loaded onto as many devices as you want (eg Android phone, tablet, Firestick, Android TV box) BUT you can only play the sub from one device at a time.") | ||||
|             .then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, "Otherwise you may lose your sub altogether!") | ||||
|             }) | ||||
|     } | ||||
| 
 | ||||
|     const updatesGroup = "- updates group"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === updatesGroup) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Got the updates group info"); | ||||
|         bot.sendMessage(msg.chat.id, "The updates groups can be found here") | ||||
|             .then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, "https://t.me/joinchat/AAAAAFfZBzZqyG3a7kU_ZA").then(() => { | ||||
|                     return bot.sendMessage(msg.chat.id, "Please join for " + channel + " updates") | ||||
|                 }) | ||||
|             }) | ||||
|     } | ||||
| 
 | ||||
|     const installOnFire = "- install filelinked on firestick"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === installOnFire) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Found out how to install on fireStick"); | ||||
|         bot.sendMessage(msg.chat.id, "Step 1:\n\nGo to Settings > device/my fire tv > developer options > apps from unknown sources on") | ||||
|             .then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, "Step 2: download an app called downloader. (Orange icon)").then(() => { | ||||
|                     return bot.sendMessage(msg.chat.id, "Step 3:\nOpen downloader and type in this address\nhttp://get.filelinked.com\nThen when it asks, install that app.").then(() => { | ||||
|                         return bot.sendMessage(msg.chat.id, "Step 4:\nPress and hold home and then click on “Apps” and scroll to the bottom and click on the very last app and open it (filelinked).").then(() => { | ||||
|                             return bot.sendMessage(msg.chat.id, "Step 5: Enter the filelinked code from the Updates page to get the list of apps for your sub") | ||||
|                         }) | ||||
|                     }) | ||||
|                 }) | ||||
|             }) | ||||
|     } | ||||
| 
 | ||||
|     const installoOnAndroid = "- install filelinked on android"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === installoOnAndroid) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Found out how to install on Android"); | ||||
|         bot.sendMessage(msg.chat.id, "First thing you need to do is go to browser on your Android TV box and enter http://get.filelinked.com") | ||||
|             .then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, "Once the apk has downloaded you can close the browser and go to your apps.").then(() => { | ||||
|                     return bot.sendMessage(msg.chat.id, "Then open file manager or file browser. In here go to downloads, filemanager, press install.").then(() => { | ||||
|                         return bot.sendMessage(msg.chat.id, "Then go back to your apps section on the box and find filelinked app.").then(() => { | ||||
|                             return bot.sendMessage(msg.chat.id, "Open the app and enter the code.") | ||||
|                         }) | ||||
|                     }) | ||||
|                 }) | ||||
|             }) | ||||
|     } | ||||
| 
 | ||||
|     const SurfShark = "- vpn (surfshark)"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === SurfShark) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Read the VPN details"); | ||||
|         bot.sendMessage(msg.chat.id, "SurfShark is the VPN that we advise you use on your device to bypass the blocks,\n\nYou can install this on your device from our FileLinked\n\nWe provide a username and password for you to use in the updates groups. DO NOT SHARE THE DETAILS"); | ||||
|     } | ||||
| 
 | ||||
|     const iptvGuidance = "- iptv guidance"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === iptvGuidance) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Read IPTV Guidance"); | ||||
|         bot.sendMessage(msg.chat.id, "🚨Basic IPTV Guidance🚨\n\nPlease see below some very basic IPTV guidance for those who are new to IPTV") | ||||
|             .then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, "1. What is a sub? A sub is what provides you with your live tv and movies/VOD... They are called different names e.g. GOLD, PREMIUM, ETC... All offer very similar channels with the difference of VOD, Series and time and money spent on servers.").then(() => { | ||||
|                     return bot.sendMessage(msg.chat.id, "2. What is an APP? An app is something that you load your sub onto, and enables you to view the channels your sub provides.").then(() => { | ||||
|                         return bot.sendMessage(msg.chat.id, "3. What is the difference m3u and Stbemu?  – you simply add a username...password  and url (M3U) to apps such as SMARTERS,XCIPTV   that you get when you purchase your sub (the username and password is in effect your sub) These subs can normally be used on multiple devices but only one at a time. Stbemu is a (mac) based app, you give the admin your mac address and they give you a portal (URL) to add to the stbemu app. The latest version on Stbemu is available in my filelinked. Stbemu subs are generally MAC, Serial and Device locked, and are not advised to anyone new to IPTV!!!!").then(() => { | ||||
|                             return bot.sendMessage(msg.chat.id, "4. For flexibility and ease of use username and password subs are far better for anyone new to IPTV –  certain subs have their own dedicated apps and are available  to download from my filelinked. I have at least one app available for every sub I sell in this room.").then(() => { | ||||
|                                 return bot.sendMessage(msg.chat.id, "5. Things you must know when using IPTV – How to refresh DNS – How to change your app player settings – How to change your app player to an external player – How to carry out basic but essential IPTV Maintenance.") | ||||
|                             }) | ||||
|                         }) | ||||
|                     }) | ||||
|                 }) | ||||
|             }) | ||||
|     } | ||||
| 
 | ||||
|     const iptvMaintenance = "- basic iptv maintenance"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === iptvMaintenance) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Read IPTV Maintenance"); | ||||
|         bot.sendMessage(msg.chat.id, "🚨Basic IPTV Maintenance🚨\n\nReboot Router, Reboot Device.\nClear all app caches - Go to settings - Applications - Manage installed applications - click on app and select clear cache. Do this for all installed applications.") | ||||
|             .then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, "To refresh DNS\nClick on add user\nRefresh DNS\nList users\nLog back in").then(() => { | ||||
|                     return bot.sendMessage(msg.chat.id, "Adding external players and changing player settings (decoder)\n\nClick the three dots in top corner and select settings.\nClick external players, and add VLC and MX Players.\nGo back one screen and click player selection.\nAt the side of live tv click whichever player you prefer, for live tv and catch up, the built in player generally works best, and choose an external player for VOD and series.\nYou may also find that changing your player setting to HW or Native can help with freezing/stuttering stream issues.").then(() => { | ||||
|                         return bot.sendMessage(msg.chat.id, "To get the most from your IPTV you have to take a little time to learn how IPTV works – How you do this is by investing a little of your time and reading through previous group messages, you do not have to read through 1000’s of messages, simply use the group search function. Also do the same with the updates group, this way your IPTV experience will be a very positive, downtime and buffer free one.").then(() => { | ||||
|                             return bot.sendMessage(msg.chat.id, "Using search function\n\nTo save time having to scroll through 1000’s of messages utilise the telegram search function, this can be used to search for specific key words.\n\nSimply click on the group name (3dots at the top right of screen)\n\nThis will bring a sub menu – select the word search and then type the word you are searching for e.g. your sub name, it will then bring up all messages featuring the word you have searched for.") | ||||
|                         }) | ||||
|                     }) | ||||
|                 }) | ||||
|             }) | ||||
|     } | ||||
| 
 | ||||
|     const doIneedVPN = "- do i need a vpn?"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === doIneedVPN) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked if they needed a VPN"); | ||||
|         bot.sendMessage(msg.chat.id, "You only need a VPN if your subscription isn't working at the time of use, normally only when the Football is on do the subs get blocked, if they do, connect using SurfShark using the details provided in the updates channel, DO NOT SHARE THESE DETAILS!"); | ||||
|     } | ||||
| 
 | ||||
|     const iptvBible = "- iptv bible"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === iptvBible) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Read the IPTV Bible"); | ||||
|         bot.sendMessage(msg.chat.id, "So the first thing I want to get out of the way is the stigma of download speeds and requirements for download speed. \r\n\r\nIn streaming like we do you will be just fine with at least 5mbps. I myself have streamed tethering off my phone with only 3mbps, but let\u2019s set the standard at 5mbps. If you have at least 5mbps and you are having issues with buffering, the download speed is not your problem. \r\n\r\nA lot of people seem to think that buffering is caused by low download speeds but that is just not true. \r\n\r\nLike I said above you can stream perfectly fine on 5mbps, in the same token you can have GB download speeds and have buffering issues.\r\n\r\nThere are a few things that will cause buffering.") | ||||
|             .then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, "1. HEAVY TRAFFIC ON THE SERVER THE LINK IS COMING FROM:\r\n\r\nYes it\u2019s nice to be able to watch movies and tv shows for free using the free links, I mean free anything is always great. But keep in mind free is not always the best. The servers that the free links come from can get congested with heavy traffic spiking the bandwidth usage of that server. \r\n\r\nThis is common during heavy streaming hours (night time and weekends). Unfortunately there is nothing you can do on your end to fix this, the only thing you can do is try another link. \r\n\r\nI highly suggest spending a few bucks for real-debrid. Real-debrid is a premium service that uses tons of premium servers all over the world. They only allow a small amount of bandwidth usage per server so you the user don\u2019t run into heavy traffic. This helps eliminate buffering. If you\u2019re still having issues with buffering using real-debrid then more then likely it\u2019s on your end. I\u2019m not saying real-debrid doesn\u2019t run into issues but It\u2019s Technology, it does have it\'s down points at times.").then(() => { | ||||
|                     return bot.sendMessage(msg.chat.id, "2. EQUIPMENT:\r\n\r\nEquipment plays a big roll in internet. If you have cheap equipment and you have the best internet provider in the world with this highest speeds, you are still going to run into issues. \r\n\r\nSo invest a good router that will perform with the speeds you are paying for. \r\n\r\nMost isp routers will not perform with the service they sell you, so it\u2019s best to purchase your own. \r\n\r\nHere is what to look for when shopping for a good router. \r\nFirst do your research on different routers and read customer reviews. \r\nSecond you want a router that is dual band, daul band has both 2.4GHz network and 5GHz network (we will get into networks later). \r\nYou could also go with a mesh system router if you really feel it\u2019s necessary. \r\nNext you want to make sure your router can cover the size of the place you live in. \r\nLook for the sq ft the router covers and be sure it will cover the sq ft of your place. \r\nNext check the speeds the router can output and either match it with the speeds your paying for or higher (I suggest going a little higher then the speeds you pay for). \r\nNext and another key factor is placement of router. \r\nYou should place your router in the center part of your house, or in a open corner so the signal can bounce off the walls and reach were it needs to send the signal.").then(() => { | ||||
|                         return bot.sendMessage(msg.chat.id, "3. NETWORK:\r\n\r\nSo as I mentioned above you want to have a dual band router. Dual band routers have two WiFi networks, 2.4GHz network and 5GHz. The 2.4GHz network is your standard WiFi network. On this network your speeds will be drastically reduced. The 2.4GHz is ideal for cellphones, computers...etc..\r\n\r\nThe 5GHz network is your powerhouse network. Like being hardwired the 5GHz network will give you your full speed and best bandwidth. \r\n\r\nThe 5GHz network is designed for streaming\/gaming. You want your firesticks to be on the 5GHz network and only your firesticks, if you have a gaming system you want that on the 5GHz network as well( I highly suggest hardwiring gaming systems if possible). Everything else in your house should be on the 2.4GHz network.\r\n\r\nThe 5GHz network is not designed to handle multiple connections at once, this is why you put all your other devices on the 2.4GHz network. You will be fine running all your firesticks at the same time on the 5GHz network as long as that\u2019s all that\u2019s on this network. Also the 5GHz network is not designed for distance, this is why it is important that you make sure you get a router that covers the sq ft of your house. I also want to clear up wrong information that gets thrown around, some people think the 5GHz network will not go through walls, this is false. The 5GHz network will most certainly go through walls. The whole 5GHz network not being able to go through walls is more towards exterior walls. So for instance if you walk outside your house you will more than likely drop your WiFi. Now I usually go into the router settings and separate the WiFi networks by putting a 5 after the name on my 5GHz network. Example- WiFi name lets say is mark, my 2.4GHz network will be named \u201Cmark\u201D and my 5GHz network will be named \u201Cmark5\u201D. Also make sure that your router is not set to choose network on its own, it\u2019s best to have that set to choose manually").then(() => { | ||||
|                             return bot.sendMessage(msg.chat.id, "4. RUNNING A SPEED TEST ON YOUR FIRE DEVICE:\r\n\r\nIf everything above has been done and you are still having issues then next you are going to want too run a speed test on your device. Go ahead and get the speed test app called \"analiti\" on your Fire Device.\r\n\r\nOn a firestick you can go to the amazon store and search for it by name or use the Alexa Mic on your remote and say \u201Cspeed test\u201D, analiti should be the first option. Now once you download analiti open it up, it will start a quick scan test just to tell you your speeds. On the left hand menu you will see a bunch of different options, the second one down is detailed test, you want to click on that. \r\n\r\nNow let the test complete before reading any numbers. Now you want to know what your bandwidth usage is at, analiti will not give you your bandwidth usage and I have yet to find a speed test that will except Xbox\u2019s speed test, but that won\u2019t do you any good because you need to perform the Speedtest on the device that is having issues(every device is going to get different results). So here is what you want to look for too determine your bandwidth usage, average latency. You will notice there are a few latency test results on this speed test, you want all of them to be an average of 30ms to 50ms. \r\n\r\nBandwidth and latency run right with each other for the most part. \r\n\r\nSo let me Break it down for you, \r\nBandwidth should be between 60ms to 80ms(the lower the better) \r\nLatency should be between 30ms and 50ms(again the lower the better). \r\n\r\nSo like I said latency runs with bandwidth, so if your latency is at 30ms then your bandwidth is 60ms give or take. If your latency is at 50ms then your bandwidth is at 80ms give or take.\r\n\r\nNext you want too check your round trip ping. \r\nThe round trip ping is the time it takes for your device to send a request to the server you are pinging to and for the server to respond back(for a better lack of words). \r\n\r\nNow this one is a tough one to determine, distance to server plays a key roll here. So if distance to server is 50 miles or less(the most common) then your ping should be from 1ms to 30ms (the lower the better) if you are pinging across state 100 miles or more then a ping from 30ms to 60ms would be fine(again the lower the number the better). \r\n\r\nIf any of that is higher, you are going to have too determine where the issue is. \r\n\r\nSo next you want to check WiFi signal strength and wifi phy speed (link speed). Be sure that your WiFi signal is good and the router can put out the speed that it\u2019s supposed to. I\u2019m sure you know how to read the signal strength so I\u2019m just going to jump into WiFi link speed. So analiti will test the capability of the routers speed. So if your router is said it can handle speeds up to 400mbps, then your WiFi speed link should show 400mbps average. If the mbps are lower then what the router is supposed to be capable of then your router is dying and you need to replace it.\r\nI also want to point out that if your WiFi signal is low and you know your router covers the sq ft of your house then that").then(() => { | ||||
|                                 return bot.sendMessage(msg.chat.id, "5. MAINTENANCE:\r\n\r\nIn order for your internet and device to run at its peak performance you will have to perform maintenance on both device and equipment. \r\nOnce a week you should unplug your router and device for at least 5 minutes. Your router stores cache just like your firestick, unplugging it for 5 minutes allows it to clear out cache and start fresh. I actually have my router on a plug timer, you can get one cheap at a Walmart or Target. \r\nI have it set to power down my router at 4AM every morning and it kicks back on at 4:05. That way I have a fresh start every morning.\r\n\r\nI hope this helps. Enjoy and happy streaming everyone.") | ||||
|                             }) | ||||
|                         }) | ||||
|                     }) | ||||
|                 }) | ||||
|             }) | ||||
|     } | ||||
| 
 | ||||
|     const howToResetCache = "- how do i clear cache?"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === howToResetCache) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked how to clear cache"); | ||||
|         bot.sendMessage(msg.chat.id, `Cache files are main source of errors and problems in functioning of Apps. By clearing cache most of the problems associated with Apps will be solved. 
 | ||||
| 
 | ||||
| To clear cache, go to Settings on your device > Application > Manage apps > Select "All" tabs, select the app which was producing error and then tap Clear cache.  | ||||
| 
 | ||||
| Do not clear data, otherwise you will have to enter your sub details into the app again.`);
 | ||||
|     } | ||||
| 
 | ||||
|     const whoAdmin = "who is an admin"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase() === whoAdmin) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked who is an admin"); | ||||
|         admins.forEach(element => | ||||
|             bot.sendMessage(msg.chat.id, element) | ||||
|         ); | ||||
|     } | ||||
| 
 | ||||
|     const startCompCalled = "start comp called"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase().includes(startCompCalled)) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked who is an admin"); | ||||
|         test = msg.text.match(/\b(\w+)$/gm); | ||||
|         fs.writeFileSync('./data/' + test + '.json', '[]') | ||||
|         bot.sendMessage(msg.chat.id, 'Comp created') | ||||
|     } | ||||
| 
 | ||||
|     const stopCompCalled = "stop comp called"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase().includes(stopCompCalled)) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked who is an admin"); | ||||
|         test = msg.text.match(/\b(\w+)$/gm); | ||||
|         fs.unlinkSync('./data/' + test + '.json', '[]') | ||||
|         bot.sendMessage(msg.chat.id, 'Comp removed') | ||||
|     } | ||||
| 
 | ||||
|     const comp = "entered the comp"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase().includes(comp)) { | ||||
|         if (admins.indexOf(msg.from.id) > -1) { | ||||
|             logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked who is an admin"); | ||||
|             user = msg.text.match(/^([\w\-]+)/gm)[0]; | ||||
|             let comp_name = msg.text.match(/\b(\w+)$/gm)[0]; | ||||
| 
 | ||||
|             comp_users = JSON.parse(fs.readFileSync('./data/' + comp_name + '.json', 'utf8')) | ||||
| 
 | ||||
|             let new_comp_users = comp_users.concat(user) | ||||
| 
 | ||||
|             fs.writeFileSync('./data/' + comp_name + '.json', JSON.stringify(new_comp_users)) | ||||
| 
 | ||||
|             bot.sendMessage(msg.chat.id, user + " has been added to the competition") | ||||
|         } else { | ||||
|             console.log('not found') | ||||
|   for (const x of jointArray) { | ||||
|     if (msg.text && msg.text.toString() === x.NAME) { | ||||
|       common.chat(bot, msg, x.NAME) | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|     const enteredTheComp = "how many in comp"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase().includes(enteredTheComp)) { | ||||
|         if (admins.indexOf(msg.from.id) > -1) { | ||||
|             let comp_name = msg.text.match(/\b(\w+)$/gm)[0]; | ||||
|             logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked who is an admin"); | ||||
|             var comp_entered = JSON.parse(fs.readFileSync('./data/' + comp_name + '.json', 'utf8')) | ||||
|             bot.sendMessage(msg.chat.id, "There are " + comp_entered.length + " people in the comp") | ||||
|         } else { | ||||
|             console.log('not found') | ||||
|   for (const x of commands) { | ||||
|     if (msg.text && msg.text.toString().includes(x.NAME)) { | ||||
|       common.commands(bot, msg, x.NAME) | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|     const whoWon = "who won comp"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase().includes(whoWon)) { | ||||
|         if (admins.indexOf(msg.from.id) > -1) { | ||||
|             let comp_name = msg.text.match(/\b(\w+)$/gm)[0]; | ||||
|             logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked who is an admin"); | ||||
|             var comp_entered = JSON.parse(fs.readFileSync('./data/' + comp_name + '.json', 'utf8')) | ||||
| 
 | ||||
|             var winner = comp_entered[Math.floor(Math.random() * comp_entered.length)]; | ||||
| 
 | ||||
|             bot.sendMessage(msg.chat.id, "There winner is .....").then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, winner) | ||||
|             }) | ||||
|         } else { | ||||
|             console.log('not found') | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| }), | ||||
|     bot.onText(/^(\/start|\/help|- Home)$/, (msg) => { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Started a Chat with me"); | ||||
|         bot.sendMessage(msg.chat.id, "I'm " + name).then(() => { | ||||
|             return bot.sendMessage(msg.chat.id, "I'm the " + channel + " Bot, and can answer your questions").then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, "Please use the buttons below to navigate", { | ||||
|                     "reply_markup": { | ||||
|                         "keyboard": [ | ||||
|                             ["- FAQ", "- Applications"] | ||||
|                         ] | ||||
|                     } | ||||
|                 }) | ||||
|             }) | ||||
|         }) | ||||
|     }) | ||||
| 
 | ||||
| 
 | ||||
| bot.onText(/^- FAQ$/, (msg) => { | ||||
|     bot.sendMessage(msg.chat.id, "Frequently Asked Questions") | ||||
|         .then(() => { | ||||
|             return bot.sendMessage(msg.chat.id, "Please only ask an Admin, if you can't find the answer here..", { | ||||
|                 "reply_markup": { | ||||
|                     "keyboard": [ | ||||
|                         ["- Subscriptions"], | ||||
|                         ["- IPTV"], | ||||
|                         ["- Apps"], | ||||
|                         ["- Home"] | ||||
|                     ] | ||||
|                 } | ||||
|             }) | ||||
|         }) | ||||
| }) | ||||
| 
 | ||||
| bot.onText(/^- Applications$/, (msg) => { | ||||
|     bot.sendMessage(msg.chat.id, "We have a number of different applications that work with our subs, here is an overview of subs/apps colour coded by the icon in our FileLinked").then(() => { | ||||
|         return bot.sendMessage(msg.chat.id, "There are 2 new XCIPTV apps, Blue and Red.\nEach have 3 different sub DNS (URLs) already embedded in the players.").then(() => { | ||||
|             return bot.sendMessage(msg.chat.id, "Sky Q app (yellow player) this holds 4 of the room subs.").then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, "All of the room subs play on the green smarters player", { | ||||
|                     "reply_markup": { | ||||
|                         "keyboard": [ | ||||
|                             ["- What app should I use?"], | ||||
|                             ["- VPN (SurfShark)"], | ||||
|                             ["- FileLinked"], | ||||
|                             ["- Home"] | ||||
|                         ] | ||||
|                     } | ||||
|                 }) | ||||
|             }) | ||||
|         }) | ||||
|     }) | ||||
| }) | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| bot.onText(/^- Subscriptions$/, (msg) => { | ||||
|     bot.sendMessage(msg.chat.id, "Subscription FAQ", { | ||||
|         "reply_markup": { | ||||
|             "keyboard": [ | ||||
|                 ["- Subscription Options"], | ||||
|                 ["- How to get a subscription?"], | ||||
|                 ["- Subscription URLs", "- Can I stream on multiple devices?"], | ||||
|                 ["- Updates Group"], | ||||
|                 ["- Install FileLinked on FireStick", "- Install FileLinked on Android"], | ||||
|                 ["- Home"] | ||||
|             ] | ||||
|         } | ||||
|     }) | ||||
| }) | ||||
| 
 | ||||
| 
 | ||||
| bot.onText(/^- IPTV$/, (msg) => { | ||||
|     bot.sendMessage(msg.chat.id, "IPTV FAQ", { | ||||
|         "reply_markup": { | ||||
|             "keyboard": [ | ||||
|                 ["- IPTV Guidance"], | ||||
|                 ["- Basic IPTV Maintenance"], | ||||
|                 ["- Do I need a VPN?"], | ||||
|                 ["- IPTV Bible"], | ||||
|                 ["- Home"] | ||||
|             ] | ||||
|         } | ||||
|     }) | ||||
| }) | ||||
| 
 | ||||
| bot.onText(/^- FileLinked$/, (msg) => { | ||||
|     logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Got the fileLinked code"); | ||||
|     bot.sendMessage(msg.chat.id, "The current FileLinked code is - " + process.env.FILELINKED_PIN + "\n\nYou can download all our players from there", { | ||||
|         "reply_markup": { | ||||
|             "keyboard": [ | ||||
|                 ["- Install FileLinked on FireStick", "- Install FileLinked on Android"], | ||||
|                 ["- Home"] | ||||
|             ] | ||||
|         } | ||||
|     }) | ||||
| }) | ||||
| 
 | ||||
| bot.onText(/^- Apps$/, (msg) => { | ||||
|     bot.sendMessage(msg.chat.id, "Apps FAQ", { | ||||
|         "reply_markup": { | ||||
|             "keyboard": [ | ||||
|                 ["- How do I clear cache?"], | ||||
|                 ["- Home"] | ||||
|             ] | ||||
|         } | ||||
|     }) | ||||
| }) | ||||
| @ -1,18 +0,0 @@ | ||||
| const fs = require('fs') | ||||
| const subs = JSON.parse(fs.readFileSync('./data/group/subs.json', 'utf8')) | ||||
| 
 | ||||
| module.exports = { | ||||
|     pricesImageList: (bot, msg, logger) => { | ||||
|         const subPrice = "- subscription options"; | ||||
|         if (msg.text && msg.text.toString().toLowerCase() === subPrice) { | ||||
|             logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Got subscription Prices"); | ||||
| 
 | ||||
|             for (var i = 0, len = subs.length; i < len; i++) { | ||||
|                 if (subs[i].IMAGE != "X") { | ||||
|                     bot.sendPhoto(msg.chat.id, subs[i].IMAGE) | ||||
|                 } | ||||
|             } | ||||
|             bot.sendMessage(msg.chat.id, "All of these prices are for 12 Month subscription subs") | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										67
									
								
								data/bot/functions/competition.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								data/bot/functions/competition.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,67 @@ | ||||
| 
 | ||||
|     const startCompCalled = "start comp called"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase().includes(startCompCalled)) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked who is an admin"); | ||||
|         test = msg.text.match(/\b(\w+)$/gm); | ||||
|         fs.writeFileSync('./data/' + test + '.json', '[]') | ||||
|         bot.sendMessage(msg.chat.id, 'Comp created') | ||||
|     } | ||||
| 
 | ||||
|     const stopCompCalled = "stop comp called"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase().includes(stopCompCalled)) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked who is an admin"); | ||||
|         test = msg.text.match(/\b(\w+)$/gm); | ||||
|         fs.unlinkSync('./data/' + test + '.json', '[]') | ||||
|         bot.sendMessage(msg.chat.id, 'Comp removed') | ||||
|     } | ||||
| 
 | ||||
|     const comp = "entered the comp"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase().includes(comp)) { | ||||
|         if (admins.indexOf(msg.from.id) > -1) { | ||||
|             logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked who is an admin"); | ||||
|             user = msg.text.match(/^([\w\-]+)/gm)[0]; | ||||
|             let comp_name = msg.text.match(/\b(\w+)$/gm)[0]; | ||||
| 
 | ||||
|             comp_users = JSON.parse(fs.readFileSync('./data/' + comp_name + '.json', 'utf8')) | ||||
| 
 | ||||
|             let new_comp_users = comp_users.concat(user) | ||||
| 
 | ||||
|             fs.writeFileSync('./data/' + comp_name + '.json', JSON.stringify(new_comp_users)) | ||||
| 
 | ||||
|             bot.sendMessage(msg.chat.id, user + " has been added to the competition") | ||||
|         } else { | ||||
|             console.log('not found') | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     const enteredTheComp = "how many in comp"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase().includes(enteredTheComp)) { | ||||
|         if (admins.indexOf(msg.from.id) > -1) { | ||||
|             let comp_name = msg.text.match(/\b(\w+)$/gm)[0]; | ||||
|             logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked who is an admin"); | ||||
|             var comp_entered = JSON.parse(fs.readFileSync('./data/' + comp_name + '.json', 'utf8')) | ||||
|             bot.sendMessage(msg.chat.id, "There are " + comp_entered.length + " people in the comp") | ||||
|         } else { | ||||
|             console.log('not found') | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     const whoWon = "who won comp"; | ||||
|     if (msg.text && msg.text.toString().toLowerCase().includes(whoWon)) { | ||||
|         if (admins.indexOf(msg.from.id) > -1) { | ||||
|             let comp_name = msg.text.match(/\b(\w+)$/gm)[0]; | ||||
|             logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked who is an admin"); | ||||
|             var comp_entered = JSON.parse(fs.readFileSync('./data/' + comp_name + '.json', 'utf8')) | ||||
| 
 | ||||
|             var winner = comp_entered[Math.floor(Math.random() * comp_entered.length)]; | ||||
| 
 | ||||
|             bot.sendMessage(msg.chat.id, "There winner is .....").then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, winner) | ||||
|             }) | ||||
|         } else { | ||||
|             console.log('not found') | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| }), | ||||
|    | ||||
							
								
								
									
										30
									
								
								data/bot/functions/faq/subscriptions.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								data/bot/functions/faq/subscriptions.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | ||||
| const fs = require('fs') | ||||
| const subs = JSON.parse(fs.readFileSync('./data/group/subs.json', 'utf8')) | ||||
| 
 | ||||
| module.exports = { | ||||
|     prices: (bot, msg, logger) => { | ||||
|         let string = "" | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Got subscription Prices"); | ||||
|         subs.forEach(element => { | ||||
|             if (element.COST != "X") { | ||||
|                 let catString = element.SUB + " - £" + element.COST + "." | ||||
|                 string += '\n' + catString; | ||||
|             } | ||||
|         }); | ||||
|         bot.sendMessage(msg.chat.id, string, { parse_mode: "HTML" }).then(() => { | ||||
|             return bot.sendMessage(msg.chat.id, "All of these prices are for 12 Month subscription subs").then(() => { | ||||
|                 return bot.sendMessage(msg.chat.id, "Keep an eye out though because we offer special deals on different subs from time to time.") | ||||
|             }) | ||||
|         }) | ||||
|     }, | ||||
|     pricesImageList: (bot, msg, logger) => { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Got subscription Prices"); | ||||
| 
 | ||||
|         for (var i = 0, len = subs.length; i < len; i++) { | ||||
|             if (subs[i].IMAGE != "X") { | ||||
|                 bot.sendPhoto(msg.chat.id, subs[i].IMAGE) | ||||
|             } | ||||
|         } | ||||
|         bot.sendMessage(msg.chat.id, "All of these prices are for 12 Month subscription subs") | ||||
|     } | ||||
| } | ||||
| @ -12,19 +12,16 @@ subArray.push(["- Home"]) | ||||
| 
 | ||||
| module.exports = { | ||||
|     main: (bot, msg, logger) => { | ||||
|         const whatAppShouldIUse = "- what app should i use?"; | ||||
|         if (msg.text && msg.text.toString().toLowerCase() === whatAppShouldIUse) { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked what app to use"); | ||||
|         bot.sendMessage(msg.chat.id, "What Subscription do you have?", { | ||||
|             "reply_markup": { | ||||
|                 "keyboard": subArray | ||||
|             } | ||||
|         }) | ||||
|         } | ||||
|     }, | ||||
|     appSwitch: (bot, msg, logger) => { | ||||
|         let string = "" | ||||
|         if (subArray.some(v => msg.text.toString().includes(v))) { | ||||
|         if (subArray.some(v => msg.text && msg.text.toString().includes(v))) { | ||||
|             var checkSub = msg.text.substring(2) | ||||
|             if (checkSub != "Home") { | ||||
|                 subs.forEach(element => { | ||||
| @ -1,3 +1,5 @@ | ||||
| const channel = process.env.CHANNEL | ||||
| 
 | ||||
| module.exports = { | ||||
|     welcomeMessage: (bot, msg, logger) => { | ||||
|         const newUserMention = "<a href=\"tg:\/\/user?id=" + msg.new_chat_member.id + "\">@" + msg.new_chat_member.first_name + "<\/a>" | ||||
							
								
								
									
										48
									
								
								data/bot/lib/common.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								data/bot/lib/common.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,48 @@ | ||||
| const decache = require('decache'); | ||||
| 
 | ||||
| module.exports = { | ||||
|     commands: async (bot, msg, input) => { | ||||
|         const userMention = "<a href=\"tg:\/\/user?id=" + msg.from.id + "\">@" + msg.from.first_name + "<\/a> " | ||||
|         let commands = require('../../group/commands') | ||||
|         for (const x of commands) { | ||||
|             if (x.NAME === input) { | ||||
|                 let n = x.NAME | ||||
|                 let t = x.TEXT | ||||
|                 for (const m of t) { | ||||
|                     let a = userMention.concat(m) | ||||
|                     await bot.sendMessage(msg.chat.id, a, { parse_mode: "HTML" }) | ||||
|                 } | ||||
|                 decache('../../group/commands'); | ||||
|                 commands = require('../../group/commands') | ||||
|             } | ||||
|         } | ||||
|     }, | ||||
|     chat: async (bot, msg, input) => { | ||||
|         const userMention = "<a href=\"tg:\/\/user?id=" + msg.from.id + "\">@" + msg.from.first_name + "<\/a> " | ||||
|         let commands = require('../../group/commands') | ||||
|         let navigation = require('../../group/FAQ') | ||||
|         let chat = require('../../group/chat') | ||||
|         let jointArray = commands.concat(navigation, chat) | ||||
| 
 | ||||
|         for (const x of jointArray) { | ||||
|             if (x.NAME === input) { | ||||
|                 let n = x.NAME | ||||
|                 let t = x.TEXT | ||||
|                 let m = JSON.parse(x.MENU) | ||||
|                 for (const d of t) { | ||||
|                     let a = userMention.concat(m) | ||||
|                     await bot.sendMessage(msg.chat.id, d, { | ||||
|                         parse_mode: "HTML", | ||||
|                         "reply_markup": { | ||||
|                             "keyboard": m | ||||
|                         } | ||||
|                     }) | ||||
|                 } | ||||
|                 decache('../../group/commands'); | ||||
|                 decache('../../group/chat'); | ||||
|                 commands = require('../../group/commands') | ||||
|                 commands = require('../../group/FAQ') | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| }; | ||||
| @ -17,7 +17,6 @@ module.exports = { | ||||
| 
 | ||||
|         let string = "" | ||||
|         const subStatus = "sub status"; | ||||
|         if (msg.text && msg.text.toString().toLowerCase().includes(subStatus)) { | ||||
|             logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " Asked how to get a subscription"); | ||||
|             subs.forEach(element => { | ||||
|                 if (element.STATUS != "X") { | ||||
| @ -35,4 +34,3 @@ module.exports = { | ||||
|             bot.sendMessage(msg.chat.id, string, { parse_mode: "HTML" }) | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										65
									
								
								data/bot/lib/requests.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								data/bot/lib/requests.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,65 @@ | ||||
| 
 | ||||
| var request = require("request"); | ||||
| var throttledRequest = require('throttled-request')(request); | ||||
| throttledRequest.configure({ requests: 8, milliseconds: 60000 }); //send 1 request per second
 | ||||
| cachedRequest = require('cached-request')(throttledRequest); | ||||
| cachedRequest.setCacheDirectory("./cache"); | ||||
| 
 | ||||
| module.exports = { | ||||
|     football_today: async (bot, msg, logger) => { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " asked for football today"); | ||||
| 
 | ||||
|         var options = { | ||||
|             method: 'GET', | ||||
|             url: 'https://football-pro.p.rapidapi.com/api/v2.0/livescores', | ||||
|             qs: { tz: 'Europe/London', leagues: '8,2,5,23,24', include: 'localTeam,visitorTeam' }, | ||||
|             headers: { | ||||
|                 'x-rapidapi-host': 'football-pro.p.rapidapi.com', | ||||
|                 'x-rapidapi-key': process.env.RAPIDAPI_API_KEY, | ||||
|                 useQueryString: true | ||||
|             }, | ||||
|             ttl: 18000000 //5 hours
 | ||||
|         }; | ||||
| 
 | ||||
|         cachedRequest(options, async function (error, response, body) { | ||||
|             if (error) throw new Error(error); | ||||
|             let jsonBody = JSON.parse(body) | ||||
|             if (jsonBody.data.length > 0) { | ||||
|                 bot.sendMessage(msg.chat.id, 'Yes there is!').then(async () => { | ||||
|                     for (const x of jsonBody.data) { | ||||
|                         var homeTeam = x.localTeam.data.name | ||||
|                         var awayTeam = x.visitorTeam.data.name | ||||
|                         var startTime = x.time.starting_at.time | ||||
|                         await bot.sendMessage(msg.chat.id, homeTeam + " VS " + awayTeam + " @ " + startTime) | ||||
|                     } | ||||
| 
 | ||||
|                 }).then(() => { | ||||
|                     return bot.sendMessage(msg.chat.id, 'To see what channels the football is streaming on please join @footballontv') | ||||
|                 }) | ||||
|             } else { | ||||
|                 bot.sendMessage(msg.chat.id, 'Sadly there is no football today :(') | ||||
|             } | ||||
|         }) | ||||
|     }, | ||||
|     joke: (bot, msg, logger, name) => { | ||||
|         logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " asked for a joke"); | ||||
| 
 | ||||
|         var options = { | ||||
|             method: 'GET', | ||||
|             url: 'https://joke3.p.rapidapi.com/v1/joke', | ||||
|             // qs: { tz: 'Europe/London', leagues: '8', include: 'localTeam,visitorTeam' },
 | ||||
|             headers: { | ||||
|                 'x-rapidapi-host': 'joke3.p.rapidapi.com', | ||||
|                 'x-rapidapi-key': process.env.RAPIDAPI_API_KEY, | ||||
|                 useQueryString: true | ||||
|             }, | ||||
|         }; | ||||
| 
 | ||||
|         request(options, function (error, response, body) { | ||||
|             if (error) throw new Error(error); | ||||
|             let jsonBody = JSON.parse(body) | ||||
|             bot.sendMessage(msg.chat.id, jsonBody.content) | ||||
|         } | ||||
|         ) | ||||
|     } | ||||
| } | ||||
| @ -1,47 +0,0 @@ | ||||
| module.exports = { | ||||
|     gamesToday: (bot, msg, logger) => { | ||||
|         const footballToday = "football today"; | ||||
|         if (msg.text && msg.text.toString().toLowerCase().includes(footballToday)) { | ||||
|             logger.info("ID - " + msg.from.id + " First Name - " + msg.from.first_name + " asked for football today"); | ||||
| 
 | ||||
|             var options = { | ||||
|                 method: 'GET', | ||||
|                 url: 'https://football-pro.p.rapidapi.com/api/v2.0/livescores', | ||||
|                 qs: { tz: 'Europe/London', leagues: '8,9,2,5,23,24', include: 'localTeam,visitorTeam' }, | ||||
|                 headers: { | ||||
|                     'x-rapidapi-host': 'football-pro.p.rapidapi.com', | ||||
|                     'x-rapidapi-key': process.env.RAPIDAPI_API_KEY, | ||||
|                     useQueryString: true | ||||
|                 }, | ||||
|                 ttl: 18000000 //5 hours
 | ||||
|             }; | ||||
| 
 | ||||
|             cachedRequest(options, function (error, response, body) { | ||||
|                 // console.log(response)
 | ||||
|                 if (error) throw new Error(error); | ||||
| 
 | ||||
|                 // console.log(body);
 | ||||
|                 let jsonBody = JSON.parse(body) | ||||
|                 if (jsonBody.data.length > 0) { | ||||
|                     bot.sendMessage(msg.chat.id, 'Yes there is!').then(() => { | ||||
|                         return jsonBody.data.forEach(function (entry) { | ||||
|                             var homeTeam = entry.localTeam.data.name | ||||
|                             var awayTeam = entry.visitorTeam.data.name | ||||
|                             var startTime = entry.time.starting_at.time | ||||
|                             // console.log(entry);
 | ||||
|                             bot.sendMessage(msg.chat.id, homeTeam + " VS " + awayTeam + " @ " + startTime) | ||||
|                         }); | ||||
|                     }).then(() => { | ||||
|                         return bot.sendMessage(msg.chat.id, 'To see what channels the football is streaming on please join @footballontv') | ||||
|                     }) | ||||
|                 } else { | ||||
|                     bot.sendMessage(msg.chat.id, 'Sadly there is no football today :(') | ||||
|                 } | ||||
|             }) | ||||
|         } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|     } | ||||
| } | ||||
							
								
								
									
										188
									
								
								data/group/FAQ.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										188
									
								
								data/group/FAQ.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,188 @@ | ||||
| const name = process.env.BOT_NAME | ||||
| const channel = process.env.CHANNEL | ||||
| 
 | ||||
| const chat = [ | ||||
|     { | ||||
|         "NAME": "/start", | ||||
|         "TEXT": [ | ||||
|             "I'm " + name, | ||||
|             "I'm the " + channel + " Bot, and can answer your questions", | ||||
|             "Please type !FAQ to open the buttons", | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "!FAQ", | ||||
|         "TEXT": [ | ||||
|             "Please use the buttons below to navigate" | ||||
|         ], | ||||
|         "MENU": '[["- FAQ", "- Applications"]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- Home", | ||||
|         "TEXT": [ | ||||
|             "Home", | ||||
|             "Please only ask an Admin, if you can't find the answer here.." | ||||
|         ], | ||||
|         "MENU": '[["- FAQ", "- Applications"]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- FAQ", | ||||
|         "TEXT": [ | ||||
|             "Frequently Asked Questions", | ||||
|             "Please only ask an Admin, if you can't find the answer here.." | ||||
|         ], | ||||
|         "MENU": '[["- Subscriptions"],["- IPTV"],["- Apps"],["- Home"]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- Applications", | ||||
|         "TEXT": [ | ||||
|             "We have a number of different applications that work with our subs, here is an overview of subs/apps colour coded by the icon in our FileLinked", | ||||
|             "There are 2 new XCIPTV apps, Blue and Red.\nEach have 3 different sub DNS (URLs) already embedded in the players.", | ||||
|             "Sky Q app (yellow player) this holds 4 of the room subs.", | ||||
|             "All of the room subs play on the green smarters player" | ||||
|         ], | ||||
|         "MENU": '[["- What app should I use?"],["- VPN (SurfShark)"],["- FileLinked"],["- Home"]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- Subscriptions", | ||||
|         "TEXT": [ | ||||
|             "Subscription FAQ" | ||||
|         ], | ||||
|         "MENU": '[["- Subscription Options"],["- How to get a subscription?"],["- Subscription URLs", "- Can I stream on multiple devices?"],["- Updates Group"],["- Install FileLinked on FireStick", "- Install FileLinked on Android"],["- Home"]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- IPTV", | ||||
|         "TEXT": [ | ||||
|             "IPTV FAQ" | ||||
|         ], | ||||
|         "MENU": '[["- IPTV Guidance"],["- Basic IPTV Maintenance"],["- Do I need a VPN?"],["- IPTV Bible"],["- Home"]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- Apps", | ||||
|         "TEXT": [ | ||||
|             "Apps FAQ" | ||||
|         ], | ||||
|         "MENU": '[["- How do I clear cache?"],["- Home"]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- How do I clear cache?", | ||||
|         "TEXT": [ | ||||
|             "Cache files are main source of errors and problems in functioning of Apps. By clearing cache most of the problems associated with Apps will be solved.\n\nTo clear cache, go to Settings on your device > Application > Manage apps > Select \"All\" tabs, select the app which was producing error and then tap Clear cache.\n\nDo not clear data, otherwise you will have to enter your sub details into the app again.", | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- IPTV Bible", | ||||
|         "TEXT": [ | ||||
|             "So the first thing I want to get out of the way is the stigma of download speeds and requirements for download speed. \r\n\r\nIn streaming like we do you will be just fine with at least 5mbps. I myself have streamed tethering off my phone with only 3mbps, but let\u2019s set the standard at 5mbps. If you have at least 5mbps and you are having issues with buffering, the download speed is not your problem. \r\n\r\nA lot of people seem to think that buffering is caused by low download speeds but that is just not true. \r\n\r\nLike I said above you can stream perfectly fine on 5mbps, in the same token you can have GB download speeds and have buffering issues.\r\n\r\nThere are a few things that will cause buffering.", | ||||
|             "1. HEAVY TRAFFIC ON THE SERVER THE LINK IS COMING FROM:\r\n\r\nYes it\u2019s nice to be able to watch movies and tv shows for free using the free links, I mean free anything is always great. But keep in mind free is not always the best. The servers that the free links come from can get congested with heavy traffic spiking the bandwidth usage of that server. \r\n\r\nThis is common during heavy streaming hours (night time and weekends). Unfortunately there is nothing you can do on your end to fix this, the only thing you can do is try another link. \r\n\r\nI highly suggest spending a few bucks for real-debrid. Real-debrid is a premium service that uses tons of premium servers all over the world. They only allow a small amount of bandwidth usage per server so you the user don\u2019t run into heavy traffic. This helps eliminate buffering. If you\u2019re still having issues with buffering using real-debrid then more then likely it\u2019s on your end. I\u2019m not saying real-debrid doesn\u2019t run into issues but It\u2019s Technology, it does have it\'s down points at times.", | ||||
|             "2. EQUIPMENT:\r\n\r\nEquipment plays a big roll in internet. If you have cheap equipment and you have the best internet provider in the world with this highest speeds, you are still going to run into issues. \r\n\r\nSo invest a good router that will perform with the speeds you are paying for. \r\n\r\nMost isp routers will not perform with the service they sell you, so it\u2019s best to purchase your own. \r\n\r\nHere is what to look for when shopping for a good router. \r\nFirst do your research on different routers and read customer reviews. \r\nSecond you want a router that is dual band, daul band has both 2.4GHz network and 5GHz network (we will get into networks later). \r\nYou could also go with a mesh system router if you really feel it\u2019s necessary. \r\nNext you want to make sure your router can cover the size of the place you live in. \r\nLook for the sq ft the router covers and be sure it will cover the sq ft of your place. \r\nNext check the speeds the router can output and either match it with the speeds your paying for or higher (I suggest going a little higher then the speeds you pay for). \r\nNext and another key factor is placement of router. \r\nYou should place your router in the center part of your house, or in a open corner so the signal can bounce off the walls and reach were it needs to send the signal.", | ||||
|             "3. NETWORK:\r\n\r\nSo as I mentioned above you want to have a dual band router. Dual band routers have two WiFi networks, 2.4GHz network and 5GHz. The 2.4GHz network is your standard WiFi network. On this network your speeds will be drastically reduced. The 2.4GHz is ideal for cellphones, computers...etc..\r\n\r\nThe 5GHz network is your powerhouse network. Like being hardwired the 5GHz network will give you your full speed and best bandwidth. \r\n\r\nThe 5GHz network is designed for streaming\/gaming. You want your firesticks to be on the 5GHz network and only your firesticks, if you have a gaming system you want that on the 5GHz network as well( I highly suggest hardwiring gaming systems if possible). Everything else in your house should be on the 2.4GHz network.\r\n\r\nThe 5GHz network is not designed to handle multiple connections at once, this is why you put all your other devices on the 2.4GHz network. You will be fine running all your firesticks at the same time on the 5GHz network as long as that\u2019s all that\u2019s on this network. Also the 5GHz network is not designed for distance, this is why it is important that you make sure you get a router that covers the sq ft of your house. I also want to clear up wrong information that gets thrown around, some people think the 5GHz network will not go through walls, this is false. The 5GHz network will most certainly go through walls. The whole 5GHz network not being able to go through walls is more towards exterior walls. So for instance if you walk outside your house you will more than likely drop your WiFi. Now I usually go into the router settings and separate the WiFi networks by putting a 5 after the name on my 5GHz network. Example- WiFi name lets say is mark, my 2.4GHz network will be named \u201Cmark\u201D and my 5GHz network will be named \u201Cmark5\u201D. Also make sure that your router is not set to choose network on its own, it\u2019s best to have that set to choose manually", | ||||
|             "4. RUNNING A SPEED TEST ON YOUR FIRE DEVICE:\r\n\r\nIf everything above has been done and you are still having issues then next you are going to want too run a speed test on your device. Go ahead and get the speed test app called \"analiti\" on your Fire Device.\r\n\r\nOn a firestick you can go to the amazon store and search for it by name or use the Alexa Mic on your remote and say \u201Cspeed test\u201D, analiti should be the first option. Now once you download analiti open it up, it will start a quick scan test just to tell you your speeds. On the left hand menu you will see a bunch of different options, the second one down is detailed test, you want to click on that. \r\n\r\nNow let the test complete before reading any numbers. Now you want to know what your bandwidth usage is at, analiti will not give you your bandwidth usage and I have yet to find a speed test that will except Xbox\u2019s speed test, but that won\u2019t do you any good because you need to perform the Speedtest on the device that is having issues(every device is going to get different results). So here is what you want to look for too determine your bandwidth usage, average latency. You will notice there are a few latency test results on this speed test, you want all of them to be an average of 30ms to 50ms. \r\n\r\nBandwidth and latency run right with each other for the most part. \r\n\r\nSo let me Break it down for you, \r\nBandwidth should be between 60ms to 80ms(the lower the better) \r\nLatency should be between 30ms and 50ms(again the lower the better). \r\n\r\nSo like I said latency runs with bandwidth, so if your latency is at 30ms then your bandwidth is 60ms give or take. If your latency is at 50ms then your bandwidth is at 80ms give or take.\r\n\r\nNext you want too check your round trip ping. \r\nThe round trip ping is the time it takes for your device to send a request to the server you are pinging to and for the server to respond back(for a better lack of words). \r\n\r\nNow this one is a tough one to determine, distance to server plays a key roll here. So if distance to server is 50 miles or less(the most common) then your ping should be from 1ms to 30ms (the lower the better) if you are pinging across state 100 miles or more then a ping from 30ms to 60ms would be fine(again the lower the number the better). \r\n\r\nIf any of that is higher, you are going to have too determine where the issue is. \r\n\r\nSo next you want to check WiFi signal strength and wifi phy speed (link speed). Be sure that your WiFi signal is good and the router can put out the speed that it\u2019s supposed to. I\u2019m sure you know how to read the signal strength so I\u2019m just going to jump into WiFi link speed. So analiti will test the capability of the routers speed. So if your router is said it can handle speeds up to 400mbps, then your WiFi speed link should show 400mbps average. If the mbps are lower then what the router is supposed to be capable of then your router is dying and you need to replace it.\r\nI also want to point out that if your WiFi signal is low and you know your router covers the sq ft of your house then that", | ||||
|             "5. MAINTENANCE:\r\n\r\nIn order for your internet and device to run at its peak performance you will have to perform maintenance on both device and equipment. \r\nOnce a week you should unplug your router and device for at least 5 minutes. Your router stores cache just like your firestick, unplugging it for 5 minutes allows it to clear out cache and start fresh. I actually have my router on a plug timer, you can get one cheap at a Walmart or Target. \r\nI have it set to power down my router at 4AM every morning and it kicks back on at 4:05. That way I have a fresh start every morning.\r\n\r\nI hope this helps. Enjoy and happy streaming everyone." | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- Do I need a VPN?", | ||||
|         "TEXT": [ | ||||
|             "You only need a VPN if your subscription isn't working at the time of use, normally only when the Football is on do the subs get blocked, if they do, connect using SurfShark using the details provided in the updates channel, DO NOT SHARE THESE DETAILS!", | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- Basic IPTV Maintenance", | ||||
|         "TEXT": [ | ||||
|             "🚨Basic IPTV Maintenance🚨\n\nReboot Router, Reboot Device.\nClear all app caches - Go to settings - Applications - Manage installed applications - click on app and select clear cache. Do this for all installed applications.", | ||||
|             "To refresh DNS\nClick on add user\nRefresh DNS\nList users\nLog back in", | ||||
|             "Adding external players and changing player settings (decoder)\n\nClick the three dots in top corner and select settings.\nClick external players, and add VLC and MX Players.\nGo back one screen and click player selection.\nAt the side of live tv click whichever player you prefer, for live tv and catch up, the built in player generally works best, and choose an external player for VOD and series.\nYou may also find that changing your player setting to HW or Native can help with freezing/stuttering stream issues.", | ||||
|             "To get the most from your IPTV you have to take a little time to learn how IPTV works – How you do this is by investing a little of your time and reading through previous group messages, you do not have to read through 1000’s of messages, simply use the group search function. Also do the same with the updates group, this way your IPTV experience will be a very positive, downtime and buffer free one.", | ||||
|             "Using search function\n\nTo save time having to scroll through 1000’s of messages utilise the telegram search function, this can be used to search for specific key words.\n\nSimply click on the group name (3dots at the top right of screen)\n\nThis will bring a sub menu – select the word search and then type the word you are searching for e.g. your sub name, it will then bring up all messages featuring the word you have searched for." | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- IPTV Guidance", | ||||
|         "TEXT": [ | ||||
|             "🚨Basic IPTV Guidance🚨\n\nPlease see below some very basic IPTV guidance for those who are new to IPTV", | ||||
|             "1. What is a sub? A sub is what provides you with your live tv and movies/VOD... They are called different names e.g. GOLD, PREMIUM, ETC... All offer very similar channels with the difference of VOD, Series and time and money spent on servers.", | ||||
|             "2. What is an APP? An app is something that you load your sub onto, and enables you to view the channels your sub provides.", | ||||
|             "3. What is the difference m3u and Stbemu?  – you simply add a username...password  and url (M3U) to apps such as SMARTERS,XCIPTV   that you get when you purchase your sub (the username and password is in effect your sub) These subs can normally be used on multiple devices but only one at a time. Stbemu is a (mac) based app, you give the admin your mac address and they give you a portal (URL) to add to the stbemu app. The latest version on Stbemu is available in my filelinked. Stbemu subs are generally MAC, Serial and Device locked, and are not advised to anyone new to IPTV!!!!", | ||||
|             "4. For flexibility and ease of use username and password subs are far better for anyone new to IPTV –  certain subs have their own dedicated apps and are available  to download from my filelinked. I have at least one app available for every sub I sell in this room.", | ||||
|             "5. Things you must know when using IPTV – How to refresh DNS – How to change your app player settings – How to change your app player to an external player – How to carry out basic but essential IPTV Maintenance." | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- Install FileLinked on Android", | ||||
|         "TEXT": [ | ||||
|             "First thing you need to do is go to browser on your Android TV box and enter http://get.filelinked.com", | ||||
|             "Once the apk has downloaded you can close the browser and go to your apps.", | ||||
|             "Then open file manager or file browser. In here go to downloads, filemanager, press install.", | ||||
|             "Then go back to your apps section on the box and find filelinked app.", | ||||
|             "Open the app and enter the code." | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- Install FileLinked on FireStick", | ||||
|         "TEXT": [ | ||||
|             "Step 1:\n\nGo to Settings > device/my fire tv > developer options > apps from unknown sources on", | ||||
|             "Step 2: download an app called downloader. (Orange icon)", | ||||
|             "Step 3:\nOpen downloader and type in this address\nhttp://get.filelinked.com\nThen when it asks, install that app.", | ||||
|             "Step 4:\nPress and hold home and then click on “Apps” and scroll to the bottom and click on the very last app and open it (filelinked).", | ||||
|             "Step 5: Enter the filelinked code from the Updates page to get the list of apps for your sub" | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- Updates Group", | ||||
|         "TEXT": [ | ||||
|             "The updates groups can be found here", | ||||
|             "https://t.me/joinchat/AAAAAFfZBzZqyG3a7kU_ZA", | ||||
|             "Please join for Bobby TV IPTV updates" | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- Can I stream on multiple devices?", | ||||
|         "TEXT": [ | ||||
|             "No. All subs sold is this room are one connection subs unless otherwise stated.\n\nThis means that you can have your sub loaded onto as many devices as you want (eg Android phone, tablet, Firestick, Android TV box) BUT you can only play the sub from one device at a time.", | ||||
|             "Otherwise you may lose your sub altogether!" | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- Subscription URLs", | ||||
|         "TEXT": [ | ||||
|             "In this IPTV room we don't give out sub URLs or m3us. We have dedicated apps to play all subs on your Android box or IPTV player in our FileLinked." | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- How to get a subscription?", | ||||
|         "TEXT": [ | ||||
|             "To purchase a subscription you need to send a DM Sarah (@bob_15).", | ||||
|             "PLEASE BE PATIENT AND WAIT FOR HER TO GET BACK TO YOU.", | ||||
|             "When you DM Sarah to purchase the subscription please let her know:\n\n1. What device the sub is going onto\n2. If there's a specific username you would like and\n3. If you don't want adult channels included. If you don't want adult channels and don't mention it when purchasing Your sub WILL be issued WITH adult channels. These can't be removed." | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- FileLinked", | ||||
|         "TEXT": [ | ||||
|             "The current FileLinked code is - " + process.env.FILELINKED_PIN + "\n\nYou can download all our players from there" | ||||
|         ], | ||||
|         "MENU": '[["- Install FileLinked on FireStick", "- Install FileLinked on Android"],["- Home"]]' | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "- VPN (SurfShark)", | ||||
|         "TEXT": [ | ||||
|             "SurfShark is the VPN that we advise you use on your device to bypass the blocks,\n\nYou can install this on your device from our FileLinked\n\nWe provide a username and password for you to use in the updates groups. DO NOT SHARE THE DETAILS" | ||||
|         ], | ||||
|         "MENU": '[[]]' | ||||
|     } | ||||
| ] | ||||
| 
 | ||||
| module.exports = chat; | ||||
							
								
								
									
										8
									
								
								data/group/chat.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								data/group/chat.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,8 @@ | ||||
| const name = process.env.BOT_NAME | ||||
| const channel = process.env.CHANNEL | ||||
| 
 | ||||
| const chat = [ | ||||
|   | ||||
| ] | ||||
| 
 | ||||
| module.exports = chat; | ||||
							
								
								
									
										17
									
								
								data/group/commands.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								data/group/commands.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,17 @@ | ||||
| const name = process.env.BOT_NAME | ||||
| const channel = process.env.CHANNEL | ||||
| 
 | ||||
| const commands = [ | ||||
|     { | ||||
|         "NAME": "/help", | ||||
|         "TEXT": [ | ||||
|             "please PM me @" + process.env.BOT_USERNAME + " and i'll try to help.", | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "NAME": "/sub_status", | ||||
|         "TEXT": [] | ||||
|     } | ||||
| ] | ||||
| 
 | ||||
| module.exports = commands; | ||||
| @ -22,5 +22,8 @@ | ||||
|     "request": "^2.88.2", | ||||
|     "require-dir": "^1.2.0", | ||||
|     "throttled-request": "^0.1.1" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "decache": "^4.6.0" | ||||
|   } | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Gogs
							Gogs