Code Monkey home page Code Monkey logo

drive-x-search-bot's Introduction

Deploy Here!

What is this repo about?

This is a telegram bot written in python for searching files in Drive.

How to deploy?

Deploying is pretty much straight forward and is divided into several steps as follows:

Installing requirements

  • Clone this repo:
git clone https://github.com/usmanmughalji/Drive-X-Search-Bot.git search-bot
cd search-bot
  • Install requirements For Debian based distros
sudo apt install python3

Install Docker by following the official Docker docs, or:

sudo snap install docker 
  • For Arch and it's derivatives:
sudo pacman -S docker python
  • Install dependencies for running setup scripts:
pip3 install -r requirements.txt

Generate Database

Click Here For More Details
  • Go to https://elephantsql.com/ and create account (skip this if you already have ElephantSQL account)
  • Hit Create New Instance
  • Follow the further instructions in the screen
  • Hit Select Region
  • Hit Review
  • Hit Create instance
  • Select your database name
  • Copy your database url, and fill to DATABASE_URL in config

Setting up config file

Click Here For More Details
cp config_sample.env config.env

Fill up rest of the fields. Meaning of each fields are discussed below:

Required Field

  • BOT_TOKEN : The telegram bot token that you get from @BotFather

  • OWNER_ID : The Telegram user ID (not username) of the owner of the bot

  • DRIVE_NAME : Add your DRIVE_NAME as follow, Seprate them with comma

    Drive1,Drive2
    
  • DRIVE_ID : Add your DRIVE_ID as follow, Seprate them with space

    AE0IwdpTBX_UkhiVAP9 115YTRH84YTr1gBz190saB7UJ1djasj9J
    
  • INDEX_URL : Add your INDEX_URL as follow, Seprate them with space

    https://demo.indexurl.workers.dev/0: https://demo.indexurl.workers.dev/0:/files
    

Optional Field

  • TELEGRAPH_TOKEN : Adding TELEGRAPH_TOKEN is compelety optional

  • AUTHORIZED_CHATS : Fill user_id and chat_id (not username) of you want to authorize, Seprate them with space Examples: -0123456789 -1122334455 6915401739

  • DATABASE_URL : Default DATABASE_URL from heroku will set itself or You can create Database URL. See Generate Database (NOTE: If you use database you can save your auth id permanent using /auth command)

  • BOT_SOURCE_CODE : Add your bot source code link here or any link you want to add here.

  • TELEGRAPH_CHANGES : Add any name here or your bot name.

Getting Google OAuth API credential file

  • Visit the Google Cloud Console
  • Go to the OAuth Consent tab, fill it, and save.
  • Go to the Credentials tab and click Create Credentials -> OAuth Client ID
  • Choose Desktop and Create.
  • Use the download button to download your credentials.
  • Move that file to the root of search-bot, and rename it to credentials.json
  • Visit Google API page
  • Search for Drive and enable it if it is disabled
  • Finally, run the script to generate token file (token.pickle) for Google Drive:
pip3 install google-api-python-client google-auth-httplib2 google-auth-oauthlib
python3 generate_drive_token.py

Deploying on Server

  • Start docker daemon (skip if already running):
sudo dockerd
  • Build Docker image:
sudo docker build . -t search-bot
  • Run the image:
sudo docker run search-bot

Credits:

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.