Crunchyroll Guest Pass Publisher for Reddit
Project description
CrunchyBot
Description:
This is a simple bot/script I made to publish my CrunchyRoll Guest Passes to Reddit. It uses Selenium and Chromedriver to extract valid guest passes from CrunchyRoll and PRAW to publish it /r/Crunchyroll's weekly Megathread. This is not a bot made to run indefinitely; however, it can be altered to do so if one so desired. It was intended for use in conjunction with a task scheduler/cronjob to check once every month (or four if you wish to publish them in sets before guest passes expire) for new guest passes.
Changes:
Due to how the PRAW library has changed, all users now must create a reddit script app. As such, the data file now must include additional data. See below for a quick guide on how to set this up.
As of 4.0.0
, binaries for chromedriver
and other tooling will not be included.
Please refer to link
on setting up and installing chromedriver
.
Setting Up Reddit Account:
- Log on to the bot account.
- Go the bot account's
preferences
from the upper-right corner. - Click the
apps
tab. - Click the
create another app
. - The button test may appear differently if you have no apps setup. - In the prompts, ensure that the
script
radio button is toggled andredirected uri
is is set tohttp://localhost:8080
. The other fields can be filled with whatever you want. - Click
create app
button when done. - You should now see the app created. Right below the name and below
personal use script
will be yourclient_id
. Within the box, to the right of the wordsecret
, is yourclient_secret
.
Prerequisites:
You will need to have Chrome installed on your system at its default installation path.
This is due to the chromedriver
working with your Chrome installation to retrieve
Crunchyroll Guest Pass.
Note As of 4.0.0
, chromedriver
will not be provided.
Please refer to link
on setting up.
Install:
pip install crunchy-bot
Setup:
Run crunchy init
to generate config file:
{
"crunchy_username": "crunchy_user",
"crunchy_password": "crunchy_pass",
"reddit_client_id": "client_id",
"reddit_client_secret": "client_secret",
"reddit_user_agent": "CrunchyBot:v4.0.0 (hosted by /u/{YOUR_USERNAME})",
"reddit_username": "reddit_user",
"reddit_password": "reddit_pass",
"log_dir": "/tmp/crunchybot/logs"
}
or save this to ~/.crunchybot
.
Execute crunchy publish [--config path/to/.crunchybot] [--debug/-d]
to start scrapping and publishing.
Development
With Pipenv
Assuming you have pipenv
installed on your system, run the following within the repo:
$ pipenv --three
This will setup a virtual environment for Crunchybot to work in without interferring your other python projects.
With pipenv
initialized, run:
$ pipenv install
This will use the Pipfile
and Pipfile.lock
to fetch and verify dependencies. Run pipenv shell
to
execute a shell into the generated virtual environment.
Without Pipenv
Install PRAW and Selenium by running the following command:
$ pip install -r requirements.txt
Once setup with or without pipenv
, run pip install -e .
within the repository. This
should install a local version of crunchy_bot
and its cli. This will also generate
a version.py
using setuptools_scm
.
Make and test your changes locally. Pull Request are welcome.
Automating:
OSX/Linux
Run crontab -e
and add
0 0 1 * * zsh -lc "/path/to/crunchy publish"
You can replace zsh -lc
with your shell's equivalent. This is mainly to execute any of your profile
presets that may handle setting up PATH
and other required environment variables to run.
Windows
Add the Python script to the Windows Task Scheduler with monthly frequency. Here is a link to setup the Task Scheduler.
Github
You can also fork this repository and utilize Github Actions
to run this task on the first of each month.
You must add the required data as all cap snake case secret variables.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file crunchy_bot-4.5.5.tar.gz
.
File metadata
- Download URL: crunchy_bot-4.5.5.tar.gz
- Upload date:
- Size: 31.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.0 requests-toolbelt/0.9.1 tqdm/4.48.0 CPython/3.7.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fa207890640c674b39c804ad00eae60052e216060181cefdbcfd9cd076297a94 |
|
MD5 | 9a095c74248890ee1d5fe97f8312c0b1 |
|
BLAKE2b-256 | c36e7282889b74afffb2242f1996ec0e41dd3e421c8d8453552e64257351cd5b |
File details
Details for the file crunchy_bot-4.5.5-py3-none-any.whl
.
File metadata
- Download URL: crunchy_bot-4.5.5-py3-none-any.whl
- Upload date:
- Size: 18.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.0 requests-toolbelt/0.9.1 tqdm/4.48.0 CPython/3.7.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7350e7935092b1537f7e54cded081ae2bdeb586fe70e7ce14272b9de3fba0088 |
|
MD5 | 4c055dbea4c6b046ea6318d6c31fe254 |
|
BLAKE2b-256 | ea3c0fa0922ea790bfae96c9c893ba8dde489db81a3b812a6de34f5ba6ed7d53 |