Metadata-Version: 2.1
Name: OnlySnarf
Version: 2.0.1
Summary: OnlyFans Content Distribution Tool
Home-page: https://github.com/skeetzo/onlysnarf
Author: Skeetzo
Author-email: WebmasterSkeetzo@gmail.com
License: UNKNOWN
Keywords: OnlyFans,Content,OnlySnarf
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: Topic :: System :: Shells
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3.4
Classifier: Operating System :: OS Independent
Description-Content-Type: text/markdown
Requires-Dist: selenium
Requires-Dist: pydrive
Requires-Dist: pathlib
Requires-Dist: chromedriver-binary (==77.0.3865.40)
Requires-Dist: moviepy
Requires-Dist: google-api-python-client
Requires-Dist: httplib2
Requires-Dist: python-crontab

# OnlySnarf

`git clone git@github.com:skeetzo/onlysnarf && sudo python3 setup.py install`
OR
`pip3 install OnlySnarf`

## Description

OnlySnarf is a python based automation tool to assist with uploading content to OnlyFans. OnlySnarf is capable of downloading and uploading a file (image or video) or gallery of files (images) from a Google Drive folder as specified by run time arguments to an OnlyFans account. OnlySnarf can mass messages fans with priced images.

## Preview
![preview](https://github.com/skeetzo/onlysnarf/blob/master/OnlySnarf/images/preview.jpeg)

## Scripts
First run:  
  * `(sudo) onlysnarf-config`
Then from within project's OnlySnarf directory either:  
  * `(sudo) onlysnarf [args]`
  * or directly via `python3 onlysnarf.py (-debug) -image|-gallery|-video`

## args

-debug  
  `python3 onlysnarf.py -debug`  
Tests configuration. Does not upload or remove from Google Drive.

-image  
  `python3 onlysnarf.py -image`  
Uploads an image labeled: 'imageName - %d%m%y'  

-gallery  
  `python3 onlysnarf.py -gallery`  
Uploads a gallery labeled: 'folderName - %d%m%y'  

-video  
  `python3 onlysnarf.py -video`  
Uploads a video labeled: 'folderName - %d%m%y'  

-text  
  `python3 onlysnarf.py -video -text "your mom"`  
Uploads a video labeled: 'your mom - %d%m%y'  

-hash(tag)  
  `python3 onlysnarf.py -hash`  
Uploads a video with the source folder split into hash tags: '#folderName'  

-force (upload)  
  `python3 onlysnarf.py -force`  
Attempts to upload limit regardless of file size. 

-show
  `python3 onlysnarf.py -show`
Shows the Chromium browser

**more available in menu**

Or include a 'profile.conf' file located at '/etc/onlysnarf/profile.conf' to set variables at runtime without using arguments. An example file has been provided. Please be sure to follow the key:value pattern. A starting # denotes a comment.

## Authentication  
--------------
The use of this package requires configuring a Google App with *PyDrive* for access to your Google Drive. The Drive API requires OAuth2.0 for authentication.
###### from [Auth Quickstart](https://raw.githubusercontent.com/gsuitedevs/PyDrive/master/docs/quickstart.rst)
1. Go to `APIs Console`_ and make your own project.
2. Search for 'Google Drive API', select the entry, and click 'Enable'.
3. Select 'Credentials' from the left menu, click 'Create Credentials', select 'OAuth client ID'.
4. Now, the product name and consent screen need to be set -> click 'Configure consent screen' and follow the instructions. Once finished:

 a. Select 'Application type' to be *Web application*.
 b. Enter an appropriate name.
 c. Input *http://localhost:8080* for 'Authorized JavaScript origins'.
 d. Input *http://localhost:8080/* for 'Authorized redirect URIs'.
 e. Click 'Create'.

5. Click 'Download JSON' on the right side of Client ID to download **client_secret_<really long ID>.json**.

**Rename the file to "client_secrets.json" and place it into your installed OnlySnarf directory.**
To update your installation with the new file, run `onlysnarf-config`, select 'Update Google Creds', and enter the location of your "client_secret.json" file.

## Config
##### config.json  
Create or update the "config.json" file with the following values:
  * username -> the Twitter connected to your OnlyFans's username  
  * password -> the Twitter conencted to your OnlyFans's password  

###### Why Twitter credentials?
OnlyFans uses a captcha to prevent malicious bots from accessing user accounts. However, this captcha is only necessary when logging in with your OnlyFans username and password. Logging in with the provided Twitter authentication does not provide a captcha and thus allows an easier automated entry.

##### google_creds.txt   
Generated by Google Drive's authentication process. Saves Google authentication for repeat access.

##### settings.yaml  
Used to facilitate Google Drive's python authentication. Requires generating an app w/ credentials via Google Console. Credentials are authenticated once and then saved to "google_creds.txt".

## Example Crons  

Upload a random image once a day at noon:  
  `* 12 * * * python3 onlysnarf.py -image`

Upload a random gallery of images every Wednesday at 2:30pm:  
  `30 14 * * 3 python3 onlysnarf.py -gallery`

Upload a random video every Friday in the month of June at 6:00pm:  
  `00 18 * 6 5 python3 onlysnarf.py -video`

Text will be generated if not provided with `-text`
  `* 12 * * * python3 onlysnarf.py -image -text "Your mother is a dirty whore"`

## Profiles

A profile of preset variables can be used by modifying the 'profile.conf' file. A config file located at `/etc/onlysnarf/profile.conf` will be prioritized.

## Dependencies
  ### Google Chrome -> `sudo apt install -y google-chrome-beta`

