From 19bfd200039dce5b20927d641149e8e1248d2d37 Mon Sep 17 00:00:00 2001 From: odysseusmax Date: Sat, 17 Jul 2021 10:05:14 +0530 Subject: [PATCH] clean up repo --- .gitignore | 1 + README.md | 115 ++++++------ app/config.py | 9 +- .replit => repl-config/.replit | 0 poetry.lock => repl-config/poetry.lock | 0 .../replit-deploy-guide.md | 166 ++++++++---------- run-dev.py => repl-config/run-dev.py | 6 +- run-repl.py => repl-config/run-repl.py | 8 +- requirements.txt | 4 +- 9 files changed, 155 insertions(+), 154 deletions(-) rename .replit => repl-config/.replit (100%) rename poetry.lock => repl-config/poetry.lock (100%) rename replit-deploy-guide.md => repl-config/replit-deploy-guide.md (56%) rename run-dev.py => repl-config/run-dev.py (87%) rename run-repl.py => repl-config/run-repl.py (84%) diff --git a/.gitignore b/.gitignore index 3546ea7..3f37279 100644 --- a/.gitignore +++ b/.gitignore @@ -3,6 +3,7 @@ __pycache__/ venv/ tests/ +Temp/ *.sh logo/ app.json diff --git a/README.md b/README.md index 02bac8d..e6b07ba 100644 --- a/README.md +++ b/README.md @@ -2,89 +2,92 @@ > Python Web App which indexes a telegram channel(or a chat) and serves its files for download. -[![Open Source Love](https://badges.frapsoft.com/os/v1/open-source.png?v=103)](.) [![GPLv3 license](https://img.shields.io/badge/License-GPLv3-blue.svg)](LICENSE) +[![Open Source Love](https://badges.frapsoft.com/os/v1/open-source.png?v=103)](.) [![GPLv3 license](https://img.shields.io/badge/License-GPLv3-blue.svg)](LICENSE) ## Highlights -* Index one or more telegram channels/chats. -* View messages and media files on the browser. -* Search through the channel/chat. -* Download media files through browser/download managers. - -## Deploy Guide (Repl.it) - -A detailed and beginner friendly guide on how to deploy this project on a free instance of https://repl.it can be found [here](replit-deploy-guide.md). +- Index one or more telegram channels/chats. +- View messages and media files on the browser. +- Search through the channel/chat. +- Download media files through browser/download managers. ## Deploy Guide -* **Clone to local machine.** +- **Clone to local machine.** -``` bash -git clone https://github.com/odysseusmax/tg-index.git -cd tg-index +```bash +$ git clone https://github.com/odysseusmax/tg-index.git + +$ cd tg-index ``` -* **Create and activate virtual environment.** +- **Create and activate virtual environment.** -``` bash -pip3 install virtualenv -virtualenv venv -source venv/bin/activate +```bash +$ python -m venv venv + +$ source venv/bin/activate ``` -* **Install dependencies.** +- **Install dependencies.** -``` bash -pip3 install -U -r requirements.txt +```bash +$ pip3 install -U -r requirements.txt ``` -* **Environment Variables.** +- **Environment Variables.** -| Variable Name | Value -|------------- | ------------- -| `API_ID` (required) | Telegram api_id obtained from . -| `API_HASH` (required) | Telegram api_hash obtained from . -| `INDEX_SETTINGS` (required) | See the below description. -| `SESSION_STRING` (required) | String obtained by running `$ python3 app/generate_session_string.py`. (Login with the telegram account which is a participant of the given channel (or chat). -| `PORT` (optional) | Port on which app should listen to, defaults to 8080. -| `HOST` (optional) | Host name on which app should listen to, defaults to 0.0.0.0. -| `DEBUG` (optional) | Give `true` to set logging level to debug, info by default. -| `BLOCK_DOWNLOADS` (optional) | Enable downloads or not. If any value is provided, downloads will be disabled. -| `RESULTS_PER_PAGE` (optional) | Number of results to be returned per page defaults to 20. -| `TGINDEX_USERNAME` (optional) | Username for authentication, defaults to `''`. -| `PASSWORD` (optional) | Password for authentication, defaults to `''`. -| `SHORT_URL_LEN` (optional) | Url length for aliases -| `SESSION_COOKIE_LIFETIME` (optional) | Number of minutes, for which authenticated session is valid for, after which user has to login again. defaults to 60. -| `SECRET_KEY` (optional) | 32 characters long string for signing the session cookies, required if authentication is enabled. +| Variable Name | Value | +| ------------------------------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `API_ID` (required) | Telegram api_id obtained from . | +| `API_HASH` (required) | Telegram api_hash obtained from . | +| `INDEX_SETTINGS` (required) | See the below description. | +| `SESSION_STRING` (required) | String obtained by running `$ python3 app/generate_session_string.py`. (Login with the telegram account which is a participant of the given channel (or chat). | +| `PORT` (optional) | Port on which app should listen to, defaults to 8080. | +| `HOST` (optional) | Host name on which app should listen to, defaults to 0.0.0.0. | +| `DEBUG` (optional) | Give `true` to set logging level to debug, info by default. | +| `BLOCK_DOWNLOADS` (optional) | Enable downloads or not. If any value is provided, downloads will be disabled. | +| `RESULTS_PER_PAGE` (optional) | Number of results to be returned per page defaults to 20. | +| `TGINDEX_USERNAME` (optional) | Username for authentication, defaults to `''`. | +| `PASSWORD` (optional) | Password for authentication, defaults to `''`. | +| `SHORT_URL_LEN` (optional) | Url length for aliases | +| `SESSION_COOKIE_LIFETIME` (optional) | Number of minutes, for which authenticated session is valid for, after which user has to login again. defaults to 60. | +| `SECRET_KEY` (optional) | 32 characters long string for signing the session cookies, required if authentication is enabled. | -* **Setting value for `INDEX_SETTINGS`** +- **Setting value for `INDEX_SETTINGS`** -This is the general format, change the values of corresponding fields as your requirements. Remember to remove spaces. +This is the general format, change the values of corresponding fields as your requirements. You can copy paste this as is to index all the channels available in your account. -``` json +**Remember to remove spaces.** + +```json { - "index_all": true, - "index_private":false, - "index_group": false, - "index_channel": true, - "exclude_chats": [], - "include_chats": [] + "index_all": true, + "index_private": false, + "index_group": false, + "index_channel": true, + "exclude_chats": [], + "include_chats": [] } ``` -> -> * `index_all` - Whether to consider all the chats associated with the telegram account. Value should either be `true` or `false`. -> * `index_private` - Whether to index private chats. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. -> * `index_group` - Whether to index group chats. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. -> * `index_channel` - Whether to index channels. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. -> * `exclude_chats` - An array/list of chat id's that should be ignored for indexing. Only considered if `index_all` is set to `true`. -> * `include_chats` - An array/list of chat id's to index. Only considered if `index_all` is set to `false`. -* **Run app.** +> - `index_all` - Whether to consider all the chats associated with the telegram account. Value should either be `true` or `false`. +> - `index_private` - Whether to index private chats. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. +> - `index_group` - Whether to index group chats. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. +> - `index_channel` - Whether to index channels. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. +> - `exclude_chats` - An array/list of chat id's that should be ignored for indexing. Only considered if `index_all` is set to `true`. +> - `include_chats` - An array/list of chat id's to index. Only considered if `index_all` is set to `false`. -``` bash +- **Run app.** + +```bash python3 -m app ``` +## Deploy Guide (Repl.it) + +A detailed and beginner friendly guide on how to deploy this project on a free instance of can be found [here](./repl-config/replit-deploy-guide.md). + ## Contributions Contributions are welcome. diff --git a/app/config.py b/app/config.py index 1c9e2c5..bf8fc53 100644 --- a/app/config.py +++ b/app/config.py @@ -1,5 +1,5 @@ from pathlib import Path -import platform +import tempfile import traceback import json import sys @@ -29,7 +29,7 @@ except (KeyError, ValueError): try: index_settings_str = os.environ["INDEX_SETTINGS"].strip() index_settings = json.loads(index_settings_str) -except: +except Exception: traceback.print_exc() print("\n\nPlease set the INDEX_SETTINGS environment variable correctly") sys.exit(1) @@ -45,9 +45,8 @@ host = os.environ.get("HOST", "0.0.0.0") debug = bool(os.environ.get("DEBUG")) block_downloads = bool(os.environ.get("BLOCK_DOWNLOADS")) results_per_page = int(os.environ.get("RESULTS_PER_PAGE", "20")) -logo_folder = Path("./Temp/logo/" if platform.system() == "Windows" else "/tmp/logo") -if not logo_folder.exists(): - logo_folder.mkdir(parents=True) +logo_folder = Path(os.path.join(tempfile.gettempdir(), "logo")) +logo_folder.mkdir(parents=True, exist_ok=True) username = os.environ.get("TGINDEX_USERNAME", "") password = os.environ.get("PASSWORD", "") SHORT_URL_LEN = int(os.environ.get("SHORT_URL_LEN", 3)) diff --git a/.replit b/repl-config/.replit similarity index 100% rename from .replit rename to repl-config/.replit diff --git a/poetry.lock b/repl-config/poetry.lock similarity index 100% rename from poetry.lock rename to repl-config/poetry.lock diff --git a/replit-deploy-guide.md b/repl-config/replit-deploy-guide.md similarity index 56% rename from replit-deploy-guide.md rename to repl-config/replit-deploy-guide.md index 99938f4..7b0b971 100644 --- a/replit-deploy-guide.md +++ b/repl-config/replit-deploy-guide.md @@ -4,200 +4,190 @@ Replit is a good place if you want to host your small sized projects and code in **NOTE : THIS GUIDE IS MADE FOR BEGINNERS LIKE PEOPLE WHO KNOW VERY LITTLE ABOUT GITHUB, REPLIT OR ANYTHING RELATED TO THIS PROJECT.** ->There's a limitation with the free version of Replit that free repls stop running automatically after a few minutes of inactivity (no traffic), it is very frustrating since web apps need to stay online 24/7 or they're useless. GOOD NEWS! for those who can't purchase or don't want to purchase the paid version, i'll introduce you to a method by which you can stop the repl from falling asleep and keep your web app online as long as possible. THANK YOU rayanfer32 on GitHub for introducing this method. +> There's a limitation with the free version of Replit that free repls stop running automatically after a few minutes of inactivity (no traffic), it is very frustrating since web apps need to stay online 24/7 or they're useless. GOOD NEWS! for those who can't purchase or don't want to purchase the paid version, I'll introduce you to a method by which you can stop the repl from falling asleep and keep your web app online as long as possible. THANK YOU `rayanfer32` on GitHub for introducing this method. NOW LET'S GET INTO BUSINESS ~ -## [1] FORK THE REPOSITORY ON GITHUB +## [1] Fork The Repository On Github It is always a good practice to make a fork of the project repo before you do anything else or instead of deploying directly from the parent repo, since any update on the parent repository will also affect your app, so this might break its stability so making a repository beforehand will save you the pain of losing the version of code that was used to deploy your app. Also, anything might happen to the parent repo or the repo owner account, so you want to ensure that the source code of your app remains intact and secure. -* So click on the 'Fork' button on the upper right corner of the tg-index repository page. This will make a copy of the current state of the source code on your GitHub account, any update on the main reposiory will not affect your forked version unless you manually choose to merge them. +- So click on the `Fork` button on the upper right corner of the repository page. This will make a copy of the current state of the source code on your GitHub account, any update on the main reposiory will not affect your forked version unless you manually choose to merge them. + +**You will have to move all the files from the `repl-config` folder to the root folder for the following steps to work.** ![image](https://user-images.githubusercontent.com/63403140/124494232-67423a00-ddd8-11eb-9b80-5c2bed010f94.png) -## [2] CREATE A REPLIT ACCOUNT +## [2] Create A Replit Account -Go to https://replit.com/signup and create a free Replit account. +Go to and create a free Replit account. -> One thing to note is that the username you use while creating a Replit account will later be used as your subdomain alias on all of your web apps, say you put `elon_musk` as your username, then the domain of your web apps will be like https://appname.elon_musk.repl.co. +> One thing to note is that the username you use while creating a Replit account will later be used as your subdomain alias on all of your web apps, say you put `elon_musk` as your username, then the domain of your web apps will be like . -## [3] CONNECT YOUR GITHUB ACCOUNT WITH YOUR REPLIT ACCOUNT +## [3] Connect Your Github Account With Your Replit Account -* Click on the 'New repl' button on upper left side of the dashboard. Then on the little window that pops up, **Import from GitHub** >> **Authorize GitHub to import your repos**. +- Click on the `New repl` button on upper left side of the dashboard. Then on the little window that pops up, **Import from GitHub** >> **Authorize GitHub to import your repos**. ![image](https://user-images.githubusercontent.com/63403140/124388284-1e20b600-dd04-11eb-8470-394abf0217a6.png) ![image](https://user-images.githubusercontent.com/63403140/124388291-2aa50e80-dd04-11eb-8df2-49a9defae22a.png) -* Then select the fork of the tg-index repo that you made earlier. +- Then select the fork of the tg-index repo that you made earlier. ![image](https://user-images.githubusercontent.com/63403140/124388476-eb2af200-dd04-11eb-8dd3-d6290738b032.png) -* After, Replit will automatically clone the repo from your GitHub fork and detect its language. It may take a few seconds to finish this initialization process and after which, your Replit window should look similar to this ~ +- After, Replit will automatically clone the repo from your GitHub fork and detect its language. It may take a few seconds to finish this initialization process and after which, your Replit window should look similar to this ~ ![image](https://user-images.githubusercontent.com/63403140/124388490-00a01c00-dd05-11eb-9161-e31076ac0416.png) > NOTE : IF YOU ALREADY HAVE A REPLIT ACCOUNT AND WANT TO DEPLOY DIRECTLY FROM THE PARENT REPO, [CLICK HERE](https://repl.it/github/odysseusmax/tg-index). IT WILL CLONE THE REPOSITORY DIRECTLY FROM THE PARENT REPO. -## [4] SET THE REQUIRED ENVIRONMENT VARIABLES +## [4] Set The Required Environment Variables -* Open the 'Secrets (Environment variables)' tab from the left sidebar, here you'll be able to add all the environment variables needed for your app. +- Open the `Secrets (Environment variables)` tab from the left sidebar, here you'll be able to add all the environment variables needed for your app. ![image](https://user-images.githubusercontent.com/63403140/124388916-cb94c900-dd06-11eb-85ba-ca42067a5ba1.png) ![image](https://user-images.githubusercontent.com/63403140/124389983-6db6b000-dd0b-11eb-8dc9-53fe29de24b8.png) -* Now add the required environment variables that your app needs to run one by one. The required environment varibles are ~ - -> NOTE : ANY VARIABLE MENTIONED IN THIS GUIDE WHICH IS MARKED AS `required` IS A REQUIRED VARIABLE THAT IS ABSOLUTELY NEEDED FOR TG-INDEX TO RUN AT MINIMAL. - -| Variable Name | Description -| ------------- | ----------- -| `API_ID` (required) | Telegram API ID obtained from https://my.telegram.org/apps. -| `API_HASH` (required) | Telegram API hash obtained from https://my.telegram.org/apps. -| `INDEX_SETTINGS` (required) | For now, just copy paste `{"index_all": true, "index_private": false, "index_group": false, "index_channel": true, "exclude_chats": [], "include_chats": []}`, we will learn how this variable works later. +- Now add the required environment variables that your app needs to run one by one. Environment variables can be found [here](../readme.md#deploy-guide) ![CYBERZENO_2021_July_04__205132](https://user-images.githubusercontent.com/63403140/124389589-ace40180-dd09-11eb-8af0-27471a2c098d.gif) -* There are actually 4 required variables for tg-index, the fourth one is a session string of your account which we will generate inside our app. So after setting the `API_ID`, `API_HASH` and `INDEX_SETTINGS` variable properly, click on the 'Run' button. +- There are actually 4 required variables for tg-index, the fourth one is a session string of your account which we will generate inside our app. So after setting the `API_ID`, `API_HASH` and `INDEX_SETTINGS` variable properly, click on the 'Run' button. ![image](https://user-images.githubusercontent.com/63403140/124390056-c2f2c180-dd0b-11eb-9058-8a029b69c79f.png) -* When running the repl for the first time, Replit will download and install all the third party packages (dependencies) needed for your app to work, so it may take a while for the process to complete. After that, a script that checks if all the required variables are present will run and when it finds that we didn't set the `SESSION_STRING` variable, it will trigger another built-in script that will ask you to type your phone number or bot API token. **TG-INDEX DOES NOT SUPPORT INDEXING CHANNELS/GROUPS USING BOTS YET** so you must type your phone number **with country code** and hit enter. +- When running the repl for the first time, Replit will download and install all the third party packages (dependencies) needed for your app to work, so it may take a while for the process to complete. After that, a script that checks if all the required variables are present will run and when it finds that we didn't set the `SESSION_STRING` variable, it will trigger another built-in script that will ask you to type your phone number or bot API token. **TG-INDEX DOES NOT SUPPORT INDEXING CHANNELS/GROUPS USING BOTS YET** so you must type your phone number **with country code** and hit enter. > NOTE : IT DOES NOT HAVE TO BE THE SAME PHONE NUMBER YOU USED TO GET THE `API_ID` AND `API_HASH` VALUES, IT IS THE PHONE NUMBER OF THE ACCOUNT OF WHICH YOU WANT TO FETCH THE CHANNELS AND GROUPS FROM. SO IT GOES WITHOUT SAYING THAT, IF YOU WANT TO INDEX A SPECIFIC CHANNEL/GROUP, THE ACCOUNT LINKED WITH THE PHONE NUMBER YOU ARE TYPING HERE NEEDS TO BE A SUBSCRIBER/MEMBER OF THAT CHANNEL/GROUP. - > NOTE : THE CHECKER SCRIPT WILL TRIGGER THE SESSION STRING GENERATOR SCRIPT ONLY IF YOU SET THE PREVIOUS THREE VARIABLES PROPERLY OR ELSE IT WILL ASK YOU TO SET THE MISSING VARIABLES INSTEAD. ![CYBERZENO_2021_July_04__214603](https://user-images.githubusercontent.com/63403140/124391193-4367f100-dd11-11eb-831d-e030f29455d8.gif) -* After that, you'll get a private message from Telegram containing an OTP, type that OTP on the console and hit enter. If the OTP is correct, a long piece of random letters and symbols will appear on your console. COPY THAT and set it as an environment varible named `SESSION_STRING` like the other three. +- After that, you'll get a private message from Telegram containing an OTP, type that OTP on the console and hit enter. If the OTP is correct, a long piece of random letters and symbols will appear on your console. COPY THAT and set it as an environment varible named `SESSION_STRING` like the other three. -* THEN, RUN THE REPL AGAIN. +- THEN, RUN THE REPL AGAIN. -* If you did everything up to this point correctly, a preview window similar to this should appear above your console ~ +- If you did everything up to this point correctly, a preview window similar to this should appear above your console ~ ![image](https://user-images.githubusercontent.com/63403140/124391976-0b62ad00-dd15-11eb-8eb6-f302ade699b4.png) -*(please don't mind my sense of privacy)* +## [5] Customize What To Index -## [5] CUSTOMIZE WHAT TO INDEX - -* Open the "Secrets (Environment variables)" sidebar again and edit the `INDEX_SETTINGS` variable to your need. The general format is ~ +- Open the `Secrets (Environment variables)` sidebar again and edit the `INDEX_SETTINGS` variable to your need. The general format is ~ > NOTE : EVERY TIME YOU ADD A NEW VARIABLE OR EDIT AN EXISTING VARIABLE, YOU MUST STOP AND RESTART YOUR REPL IF IT'S ALREADY RUNNING. - > NOTE : USING THESE EXACT SAME SETTINGS WILL ALLOW YOUR APP TO FETCH ALL OF YOUR PUBLIC AND PRIVATE CHANNELS. IT WON'T INDEX YOUR PUBLIC/PRIVATE GROUPS AND PRIVATE CHATS WITH PEOPLES/BOTS ```json { - "index_all": true, - "index_private": false, - "index_group": false, - "index_channel": true, - "exclude_chats": [], - "include_chats": [] + "index_all": true, + "index_private": false, + "index_group": false, + "index_channel": true, + "exclude_chats": [], + "include_chats": [] } ``` > NOTE : `INDEX_SETTINGS` IS A REQUIRED VARIABLE SO, ALL THE SUB-VARIABLES OF `INDEX_SETTINGS` MENTIONED BELOW ARE ALSO REQUIRED VARIABLES. -| Variable Name | Description -| ------------- | ----------- -| `index_all` | Whether to consider all the chats associated with the Telegram account. Value should either be `true` or `false`. -| `index_private` | Whether to index private chats. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. -| `index_group` | Whether to index group chats. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. -| `index_channel` | Whether to index channels. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. -| `exclude_chats` | An array/list of chat id's that should be ignored for indexing. Only considered if `index_all` is set to `true`. Example : `"exclude_chats": [-123456789, -987654321, -147258369]` -| `include_chats` | An array/list of chat id's to index. Only considered if `index_all` is set to `false`. Example : `"include_chats": [-123456789, -987654321, 147258369]` +| Variable Name | Description | +| --------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `index_all` | Whether to consider all the chats associated with the Telegram account. Value should either be `true` or `false`. | +| `index_private` | Whether to index private chats. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. | +| `index_group` | Whether to index group chats. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. | +| `index_channel` | Whether to index channels. Only considered if `index_all` is set to `true`. Value should either be `true` or `false`. | +| `exclude_chats` | An array/list of chat id's that should be ignored for indexing. Only considered if `index_all` is set to `true`. Example : `"exclude_chats": [-123456789, -987654321, -147258369]` | +| `include_chats` | An array/list of chat id's to index. Only considered if `index_all` is set to `false`. Example : `"include_chats": [-123456789, -987654321, 147258369]` | -### SOME `INDEX_SETTINGS` EXAMPLES +### Some `INDEX_SETTINGS` Examples -* If you want to only index the channel with the channel ID `-123456789`, then the value of your `INDEX_SETTINGS` variable should be ~ +- If you want to only index the channel with the channel ID `-123456789`, then the value of your `INDEX_SETTINGS` variable should be ~ ```json { - "index_all": false, - "index_private": false, - "index_group": false, - "index_channel": true, - "exclude_chats": [], - "include_chats": [-123456789] + "index_all": false, + "index_private": false, + "index_group": false, + "index_channel": true, + "exclude_chats": [], + "include_chats": [-123456789] } ``` -* If you want to index every public/private channel on your account except a channel with the channel ID `-123456789`, the value of your `INDEX_SETTINGS` variable should be ~ +- If you want to index every public/private channel on your account except a channel with the channel ID `-123456789`, the value of your `INDEX_SETTINGS` variable should be ~ ```json { - "index_all": true, - "index_private": false, - "index_group": false, - "index_channel": true, - "exclude_chats": [-123456789], - "include_chats": [] + "index_all": true, + "index_private": false, + "index_group": false, + "index_channel": true, + "exclude_chats": [-123456789], + "include_chats": [] } ``` -* if you want to index every single chat, channel and group on your Telegram account, the value of your `INDEX_SETTINGS` variable should be ~ +- if you want to index every single chat, channel and group on your Telegram account, the value of your `INDEX_SETTINGS` variable should be ~ **WARNING!! IT IS NOT RECOMMENDED TO SET `INDEX_SETTINGS` VARIABLE TO INDEX EVERYTHING INCLUDING YOUR PRIVATE CHATS AS THEY WILL BE OPENLY AVAILABLE FOR EVERYONE TO SEE ON THE INTERNET. EVEN IF YOU WANT TO INDEX EVERYTHING, IT IS HIGHLY RECOMMENDED THAT YOU SET USERNAME & PASSWORD FOR YOUR INDEX. LEARN HOW TO DO THIS IN THE NEXT STEP.** ```json { - "index_all": true, - "index_private": true, - "index_group": true, - "index_channel": true, - "exclude_chats": [], - "include_chats": [] + "index_all": true, + "index_private": true, + "index_group": true, + "index_channel": true, + "exclude_chats": [], + "include_chats": [] } ``` -## [6] SET USERNAME & PASSWORD FOR YOUR INDEX (Optional) +## [6] Set Username & Password For Your Index (Optional) -* Just add these three environment variables in the "Secrets (Environment variables)" sidebar ~ +- Just add these three environment variables in the "Secrets (Environment variables)" sidebar ~ -| Variable Name | Description -| ------------- | ----------- -| `TGINDEX_USERNAME` | Username for authentication, defaults to `''`. -| `PASSWORD` | Password for authentication, defaults to `''`. -| `SECRET_KEY` | 32 characters long string for signing the session cookies, required if authentication is enabled. You can use [LastPass Password Generator](https://www.lastpass.com/password-generator) or any other password generator to generate a secure key. +| Variable Name | Description | +| ------------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `TGINDEX_USERNAME` | Username for authentication, defaults to `''`. | +| `PASSWORD` | Password for authentication, defaults to `''`. | +| `SECRET_KEY` | 32 characters long string for signing the session cookies, required if authentication is enabled. You can use [LastPass Password Generator](https://www.lastpass.com/password-generator) or any other password generator to generate a secure key. | -* Some optional variables for additional security to set while setting the login credentials are ~ +- Some optional variables for additional security to set while setting the login credentials are ~ -| Variable Name | Description -| ------------- | ----------- -| `SESSION_COOKIE_LIFETIME` | Number of minutes, for which authenticated session is valid for, after which user has to login again. defaults to 60. -| `BLOCK_DOWNLOADS` | Enable downloads or not. If any value is provided, download feature will be disabled. +| Variable Name | Description | +| ------------------------- | --------------------------------------------------------------------------------------------------------------------- | +| `SESSION_COOKIE_LIFETIME` | Number of minutes, for which authenticated session is valid for, after which user has to login again. defaults to 60. | +| `BLOCK_DOWNLOADS` | Enable downloads or not. If any value is provided, download feature will be disabled. | -## [7] HOW TO KEEP YOUR REPL ONLINE +## [7] How To Keep Your Repl Online So the biggest disadvantage of free repls is that they go offline after a few minutes (~5 minitues) of inactivity so what we need for your repl to keep active is a service that will keep sending a timely ping so that the repl doesn't fall asleep. UptimeRobot offers a free service that can do exactly that. Basically, it's a monitoring service that sends an HTTP request to your repl every 5 minutes to check whether your site is down and this checking process does the trick, so your repl stays online. -* Go to https://uptimerobot.com/signUp and create an account. Verify your email and login to your account. +- Go to and create an account. Verify your email and login to your account. > NOTE : IT IS RECOMMENDED THAT YOU USE AN EMAIL ADDRESS THAT YOU HAD SET UP ON YOUR MOBILE PHONE AS THE SERVICE WILL SEND YOU AN EMAIL TO THIS ADDRESS IF YOUR REPL GOES OFFLINE FOR SOME REASON. -* Your dashboard after login should look something similar to this ~ +- Your dashboard after login should look something similar to this ~ ![image](https://user-images.githubusercontent.com/63403140/124481894-9782dc00-ddca-11eb-9301-c0c23786c694.png) -* Click on "Add New Monitor", and then from the "Monitor type" dropdown menu, select 'HTTP(s)'. +- Click on "Add New Monitor", and then from the "Monitor type" dropdown menu, select 'HTTP(s)'. ![image](https://user-images.githubusercontent.com/63403140/124482201-dc0e7780-ddca-11eb-81a2-911aa968efd4.png) ![image](https://user-images.githubusercontent.com/63403140/124490567-12042980-ddd4-11eb-8d7d-163cb9fd9eaa.png) -* Give this monitor a friendly name, copy your app URL from the box above the preview window of Replit and paste it in the "URL (or IP)" field of the monitor. +- Give this monitor a friendly name, copy your app URL from the box above the preview window of Replit and paste it in the "URL (or IP)" field of the monitor. ![image](https://user-images.githubusercontent.com/63403140/124488177-5e019f00-ddd1-11eb-8764-83dcba9146cb.png) ![image](https://user-images.githubusercontent.com/63403140/124488212-65c14380-ddd1-11eb-8373-ec72ef486a50.png) -* Scroll down and click on "Create Monitor", and you're done setting up the monitoring service. +- Scroll down and click on "Create Monitor", and you're done setting up the monitoring service. ![image](https://user-images.githubusercontent.com/63403140/124488978-4bd43080-ddd2-11eb-8f0b-d587f263a7c9.png) -Again, thank you @rayanfer32 for introducing this amazing method, this is the biggest reason for making this guide. +Again, thank you [@rayanfer32](https://github.com/rayanfer32) for introducing this amazing method, this is the biggest reason for making this guide. THAT IS ALL! -**If you face any issue or something out of the ordinary while following this guide, drop me a word at [Telegram](https://t.me/pseudokawaii). I'll try to help you if i'm not busy.** +**If you face any issue or something out of the ordinary while following this guide, drop me a word at [Telegram](https://tx.me/pseudokawaii). I'll try to help you if I'm not busy.** diff --git a/run-dev.py b/repl-config/run-dev.py similarity index 87% rename from run-dev.py rename to repl-config/run-dev.py index 1708cf6..d850fdf 100644 --- a/run-dev.py +++ b/repl-config/run-dev.py @@ -8,6 +8,7 @@ load_dotenv() # take environment variables from .env. # os.system("alias python3=python") + def runSetup(): def alert(missing): print(f"\nCopy your {missing} and save it as an environment variable.\n") @@ -22,10 +23,13 @@ def runSetup(): if os.getenv("SESSION_STRRING") is None: os.system("python app/generate_session_string.py") - print("\nCopy your SESSION_STRING from above and save it as an environment variable.") + print( + "\nCopy your SESSION_STRING from above and save it as an environment variable." + ) return os.system("python -m app") + if __name__ == "__main__": runSetup() diff --git a/run-repl.py b/repl-config/run-repl.py similarity index 84% rename from run-repl.py rename to repl-config/run-repl.py index 50e0c78..819dbed 100644 --- a/run-repl.py +++ b/repl-config/run-repl.py @@ -5,6 +5,7 @@ import os os.system("alias python3=python") + def runSetup(): def alert(missing): print( @@ -18,13 +19,16 @@ def runSetup(): if env_value is None: alert(env_var) return - + if os.getenv("SESSION_STRING") is None: os.system("python app/generate_session_string.py") - print("\nCopy your SESSION_STRING from above and save it into Secrets (Environment variables) Sidebar!") + print( + "\nCopy your SESSION_STRING from above and save it into Secrets (Environment variables) Sidebar!" + ) return os.system("python -m app") + if __name__ == "__main__": runSetup() diff --git a/requirements.txt b/requirements.txt index 11183ae..91e019c 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,6 +1,6 @@ -aiohttp[speedups] +aiohtt aiohttp-jinja2 -telethon>=1.16.4 +telethon cryptg pillow aiohttp_session[secure]