Skip to content

Latest commit

 

History

History
152 lines (107 loc) · 5.57 KB

README.md

File metadata and controls

152 lines (107 loc) · 5.57 KB

Microsoft-Rewards-Bot

Microsoft Rewards (Bing Rewards) Bot - Completes searches and quizzes , written in Python! 🙌

Overview

This program will automatically complete search requests and quizzes on Microsoft Rewards! Search terms are the daily top searches retrieved using Google Trends' api. This bot runs selenium in headless mode for deployment on VPS and for increased performance on local machines. The bot also uses selenium's user agent options to fulfill points for all three platforms (pc, edge browser, mobile). 100% free to use and open source. Code critique/feedback and contributions welcome!

Features

  • Completes PC search, Edge search, Mobile search via user agents
  • Retrieves top daily searches via google trends' API
  • Completes polls, all types of quizzes (multiple choice, click and drag and reorder), and explore dailies
  • Headless mode (Confirmed working on DigitalOcean linux droplet)
  • Supports unlimited accounts via JSON, in randomized order.
  • Randomized search speeds
  • Logs errors and info by default, can log executed commands and search terms via changing log.level to logging.DEBUG
  • Tested and confirmed working for U.S. (more to come!)

REQUIREMENTS

  • Python 3.6

  • Requests 2.21.0

  • Selenium 3.14.0

  • Chrome Browser

HOW TO USE

  1. Clone and navigate to repo

  2. Modify ms_rewards_login_dict.json with your account names and passwords, remove .example from filename.

  3. Enter into cmd/terminal/shell: pip install -r requirements.txt

    • This installs dependencies (selenium)
  4. Enter into cmd/terminal/shell: python ms_rewards.py --headless --mobile --pc --quiz

    • enter -h or --help for more instructions
      • --headless is for headless mode
      • --mobile is for mobile search
      • --pc is for pc search
      • --quiz is for quiz search
      • -a or --all is short for mobile, pc, and quiz search
    • Script by will execute mobile, pc, edge, searches, and complete quizzes for all accounts (can change this setting in the .py file)
    • Script by default will run headlessly (can change this setting in the .py file)
    • Run time for one account is under 5 minutes, for 100% daily completion
    • If python environment variable is not set, enter /path/to/python/executable ms_rewards.py
  5. For completing points from email links:

    • Modify email_links.txt file with email links.

      • Copy and paste links without surrounding quotes, each on individual line, like such:

          httplink1
          httplink2
          httplink3
        
    • Enter cmd/terminal/shell argument python ms_rewards.py --email

    • Script will be manual, requires key press to continue, as the quizzes are not yet standardized.

  6. Crontab (Optional for automated script daily on linux)

    • Enter in terminal: crontab -e
    • Enter in terminal: 0 12 * * * /path/to/python /path/to/ms_rewards.py --headless --mobile --pc --quiz
      • Can change the time from 12am server time to whenever the MS daily searches reset (~12am PST)
    • Change the paths to the json in the .py file to appropriate path

TO DO

  • Argparse for options:
    • logging
    • custom user agents
  • Rewrite script into class-based code or Organize monolithic code into different py files for maintainability
  • os.environ variables for multiple logins (current account names and passwords are too long)
  • Proxy support
  • Multithreaded mode or seleniumGrid
  • Support for other regions

License

100% free to use and open source. 🙈 🙉 🙊

Versions

2019.04.03

- Added fix for wait_until_visible from .find_element to .find_elements

2019.04.02

- Added adreo00's code for setting log level with argparse

2019.04.01

- Added fix for detecting pcpoints element during point status check
- Removed edge points as the status screen no longer displays them

2019.03.01

- Incorporated ShoGinn's lightning quiz fix
- Fixed .cico quiz close patch
- Added const for logging level

2019.02.02

- Fixed open offer link to target the link

2019.02.01

- Added chromedriver auto-downloading

2019.01.01

- Error handling for 'credits2', function should exit and script should continue to execute.

2019.01

- Migrated to chrome/chromedriver 
    - Immediate improvement in speed and stability over firefox/geckodriver
    - Appears to use less RAM than firefox (suprisingly..)
    - May be possible to run on raspberrypi (rpi has chromedriver)
- Mitigated credits2 error by performing an action before going to search URL

2018.04

- Performance improvements
- Fixed login, now waits until page is fully loaded
- Replaced urllib api call with requests
- Updated get points with chrome extension source, less prone to error (credit to Shoginn for the url!)
- Updated quizzes to log open quiz offers, completed quiz offers, all points
- Modified error catching for alerts, combined with timeoutexception
- Misc fixes

2018.03

- Fixed issue with daily poll IDs changing
- Added check for sign-in prompt after click on a quiz 
- Misc fixes

2018.02

- Added argparse
- Added points from email links
- Added randomized account login order
- Reworked newsapi.org API to google trends
- Fixed logging
- Fixed issue with dropped searches

2018.01

- Initial release
- Basic functionality for completing searches and quizzes.  

Special Thanks

@ShoGinn - for extraordinary assistance in making this project better!