Crates.io | shreddit |
lib.rs | shreddit |
version | 0.9.3 |
source | src |
created_at | 2022-04-13 22:16:36.010598 |
updated_at | 2023-12-13 17:42:07.884915 |
description | Overwrite and delete your Reddit account history. |
homepage | |
repository | https://github.com/andrewbanchich/shreddit |
max_upload_size | |
id | 567240 |
size | 90,300 |
shreddit
is a tool to delete Reddit comments and posts.
Deactivating a Reddit account will not delete comments or submissions - it will only disassociate your account from them.
Shreddit overwrites your comments with random text before deleting them to ensure that the originals are (probably) not preserved.
If you don't want your post history to follow you around forever, you can use shreddit
on a cron job.
If you're deactivating your account, you can run shreddit
first to ensure your posts are deleted.
Because the original Shreddit project was abandoned in 2017, I decided to rewrite it in Rust.
This brings several benefits:
shreddit.yml
and praw.ini
config files, all configuration can be done through CLI commands
with environment variables as default fallbacks.Download the binary from the GitHub Releases page.
cargo install shreddit
create another app...
script
.http://localhost:8080
.create app
.This will provide with a client ID and client secret. The CLIENT_ID
value used by Shreddit is shown under the name of the app you created. The CLIENT_SECRET
is shown after clicking edit
.
IMPORTANT: If you are using TOTP, you will need to pass it in via the
PASSWORD
settings likePASSWORD:TOTP
. It's currently a bit awkward to do since you need to do so before the token expires, so in the future we can add a CLI prompt to make this easier. In the meantime, you can just use the--password
CLI argument, fill in--password your-password:
and paste the TOTP after that and hit enter.
Overwrite and delete your Reddit account history.
Usage: shreddit [OPTIONS] --username <USERNAME> --password <PASSWORD> --client-id <CLIENT_ID> --client-secret <CLIENT_SECRET>
Options:
-u, --username <USERNAME>
Your Reddit username [env: SHREDDIT_USERNAME=]
-p, --password <PASSWORD>
Your Reddit password [env: SHREDDIT_PASSWORD=]
--client-id <CLIENT_ID>
To create client credentials, you need to navigate to `https://www.reddit.com/prefs/apps/`, click `create another app...` and fill out the form. Select the `script` type, and set `redirect uri` as `http://localhost:8080` [env: SHREDDIT_CLIENT_ID=]
--client-secret <CLIENT_SECRET>
The client secret from when you created client credentials [env: SHREDDIT_CLIENT_SECRET=]
--dry-run
If set, shreddit will not modify or delete anything. It will simply log what it would do if not in dry run mode. This allows you to preview the plan of action before executing [env: SHREDDIT_DRY_RUN=]
--thing-types <THING_TYPES>
What "things" you want to delete [env: SHREDDIT_THING_TYPES=] [default: posts comments] [possible values: posts, comments, friends, saved-posts, saved-comments]
--before <BEFORE>
[env: SHREDDIT_BEFORE=] [default: "2023-06-25 14:42:43.828192320 UTC"]
--max-score <MAX_SCORE>
[env: SHREDDIT_MAX_SCORE=]
-r, --replacement-comment <REPLACEMENT_COMMENT>
Allows a user to specify a custom string as their comment replacement text [env: SHREDDIT_REPLACEMENT_COMMENT=] [default: "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."]
--user-agent <USER_AGENT>
The User-Agent for Reddit API requests [env: SHREDDIT_USER_AGENT=] [default: ShredditRustClient]
--gdpr-export-dir <GDPR_EXPORT_DIR>
The path of the directory of the unzipped GDPR export data. If set, `shreddit` will use the GDPR export folder instead of Reddit's APIs for discovering your data [env: SHREDDIT_GDPR_EXPORT_DIR=]
--edit-only
If specified, comments will only be edited, not deleted. - Requires gdpr_export [env: SHREDDIT_EDIT_ONLY=]
-h, --help
Print help
-V, --version
Print version
You can choose to pass in configuration settings via CLI arguments like:
shreddit --username YouRedditUsername --password YourSuperSecretPassword123 --client-id k1jh2342k3j --client-secret 2345JHLJ_34kjhkj3h453453
or by setting them as environment variables (e.g. SHREDDIT_CLIENT_SECRET
) and simply running shreddit
.
On startup, shreddit
looks for a shreddit.env
file in the current directory and sets any variables declared there.
However, this is purely optional.
You can use --dry-run
or SHREDDIT_DRY_RUN=true
to see what it would do without it actually doing anything.
shreddit
with the --gdpr-export-dir
flag set to the path of the directory it was extracted to.These are the other features Python Shreddit had.
I'll be adding these as I go along. PRs are welcome!
Other feature ideas are welcome.