Skip to content

A WhatsApp bot πŸ€– written in JavaScript and Node.js.

Notifications You must be signed in to change notification settings

eyalmichon/TheMultitasker

Repository files navigation

πšπš‘πšŽ_πš–πšžπš•πšπš’πšπšŠπšœπš”πšŽπš›;

A WhatsApp bot written in JavaScript and Node.js.

forthebadge

Latest Changes

Features

Command pattern used for easy management of adding more commands.

  • Owner Commands πŸ‘‘:

    • Send Red Alerts πŸš€ as message with (or without) location on GoogleMaps.
    • Add and remove senders from sending groups (senders.json) straight from Whatsapp.
    • Kick 🦢 all participants from group.
    • Get a list of names from a specific group.
    • Get all group IDs of the groups sent to owner.
    • Spam-tag someone to get their attention.
    • Blacklist πŸ“› for country codes and participants
    • Expand groups with build-in Group Expander.
    • Set ON/OFF: get a welcome message when someone joines the group.
    • Count messages containing a sentence (or multiple sentences) in a group.
    • Spam any type of message to a group.
  • Admin Commands πŸ’Ό:

    • Tag everyone in the group.
    • Kick 🦢 a participant from group.
    • Add a user to the group.
    • Promote/Demote users.
    • Get group invite link.
    • Mute/Unmute group members πŸ”‡
    • Get the profile picture of a participant.
  • Social Commands 🌐:

    • Get a random 🎲 meme/post from a set of subreddits you choose or a specifc one.
    • Download all types of content from Instagram.
    • Download video/audio from:
    • Download music from Deezer. (need premium account)
  • Info Commands β„Ή:

    • Compile πŸ‘¨β€πŸ’» and get output from many languages like Python 🐍, C, Java, etc....
    • Get COVID-19 🦠 updates for many countries.
    • Get answers to questions ❓ from WolframAlpha.
    • Get definition of words / Word of the day / random word from Urban Dictionary.
    • Translate sentences using Google Translate.
    • Fix grammar.
    • Text to speech.
    • Translate with context.
    • Synonyms & Antonyms.
    • Conjugate words/sentences.
    • get this doesn't exist content from this collection
    • Get info on cars πŸš— and motorcycles 🏍 in Israel.
    • Currency checking. πŸ’±πŸ’΅
  • AI Commands πŸ€–:

    • Recognize music πŸ‘‚πŸŽΆ.
    • Imagine, text to image generation. πŸ–Ό
    • Enhance image quality. πŸ–Ό
    • Summarize text. πŸ“
    • Get topics of text. πŸ“Œ
    • Split text by sentences. πŸ“ƒ
    • Anonymize text. πŸ•΅οΈβ€β™‚οΈ
    • Get contents of a website. 🌐
    • Transcribe audio. πŸŽ™
    • AI detector for text. πŸ•΅οΈβ€β™‚οΈ
    • Excuse generator. πŸ€·β€β™‚οΈ
    • Random Idea generator. πŸ’‘
    • Dream Interpretation. πŸŒ™
    • SQL Fixer. πŸ›
    • SQL Explainer. πŸ“–
    • Colorize image. 🎨
    • Upscale image. πŸ–Ό
    • Generate prayers. πŸ™
  • Forwarder Commands ⏩:

    • Forward messages randomly from a chosen group. (group IDs need to be set manually)
  • Sticker Commands πŸ˜€:

    Create stickers from:

    • Image πŸ“·:
      • add stroke.
      • add text.
      • change background.
    • Video πŸŽ₯
    • GIF πŸ‘Ύ
    • URL πŸ”—
    • Stickers πŸ˜ƒ
    • All types of chat messages πŸ’¬
  • Media Commands πŸ–Ό:

    • Remove background:
      • add stroke.
      • add text.
      • change background.
    • Convert video to voice message.
    • Sticker to image.

Dependencies

Installation

clone the project:

git clone https://github.com/eyalmichon/TheMultitasker.git

then inside the project folder use the following command to install required packages:

npm install

next, make sure all of the dependencies are installed.

Now you'll need to create a senders file in json format at ./handler/util which you can use to save your group/private numbers for different functions safely without being part of the code.

Example senders.json:

The group info needed here is the JID of the group. (which looks like this "****-****@g.us") Same thing for regular users (which is the phone number with @c.us appended)

{
  "Me": "****@c.us",
  "Allowed": [
    "****-****@g.us",
    "****@c.us"
  ],
  "WelcomeMsg": ["****-****@g.us"],
  "RedAlerts-MessageOnly": [""],
  "RedAlerts": [""],
  "ProjectEgg": "****-****@g.us",
  "Fartictionary": "****-****@g.us"
}

Now if you want to use any api that is using image uploading / music recognition / better background removal you'll need to create an account on imgur and get a client ID and secret and place them in a new secrets.json file located at ./handler/util folder .

Example secrets.json:

{
    "Imgur": {
        "ID": "*********",
        "secret": "***********************************"
    },
    "ACRCloud": [{
            "host": "******",
            "endpoint": "******",
            "signature_version": "******",
            "data_type": "******",
            "secure": "******",
            "access_key": "******",
            "access_secret": "******"
        }],
    "removebg":["******"],
    // you'll need to get this yourself from mage dot space
    "imagineSecrets": {
        "apiUrl": "",
        "enhanceUrl": "",
        "refferer": "",
        "googleApi": "",
        "x-client-data": "",
        "x-client-version": "",
        "x-firebase-gmpid": ""
    },
    "AISecrets": {
      // you'll need to get this yourself from one ai dot come
        "oneai": {
            "keys": [
            ],
            "apiEndpoint": "",
            "AISignInAPI": ""
        },
        "contentDetector": {
          // you'll need to get this yourself from writer dot com
            "short": {
                "apiEndpoint": ""
            },
            // you'll need to get this yourself from copy leaks dot com
            "long": {
                "apiEndpoint": "",
                "referrer": ""
            }
        },
        // you'll need to get this yourself from excuses dot ai
        "excuseGenerator": {
            "apiEndpoint": "",
            "referrer": ""
        },
        // you'll need to get this yourself from ideas ai dot com
        "randomIdea": {
            "apiEndpoint": ""
        },
        // you'll need to get this yourself from dream interpreter dot ai
        "dreamInterpretation": {
            "apiEndpoint": "",
            "referrer": ""
        },
        // you'll need to get this yourself from air ops dot com
        "sql": {
            "apiEndpoint": ""
        }
    }
}

Now, inside index.js change executablePath path in the options to where you've installed chrome OR try the useChrome option and it may guess the location corretly.

Running & Usage

npm start

scan the QR code and wow, you're done!