API client for Truth Social
Project description
truthbrush
Truthbrush is an API client for Truth Social.
Currently, this tool can:
- Search for users, statuses, groups, or hashtags
- Pull a user's statuses
- Pull the list of "People to Follow" or suggested users
- Pull "trending" hashtags
- Pull "trending" Truth posts
- Pull ads
- Pull a user's metadata
- Pull the list of users who liked a post
- Pull the list of comments on a post
- Pull "trending" groups
- Pull list of suggested groups
- Pull "trending" group hashtags
- Pull posts from group timeline
Truthbrush is designed for academic research, open source intelligence gathering, and data archival. It pulls all data from the publicly accessible API.
Installation
From PyPi:
pip install truthbrush
From git:
- To install it, run
pip install git+https://github.com/stanfordio/truthbrush.git
From source:
- Clone the repository and run
pip3 install .. Provided yourpipis setup correctly, this will maketruthbrushavailable both as a command and as a Python package.
After installation, you will need to set your Truth Social username and password as environmental variables.
export TRUTHSOCIAL_USERNAME=foo
export TRUTHSOCIAL_PASSWORD=bar
If you encounter login issues, you can instead extract your login token from the truth:auth Local Storage store and export it in TRUTHSOCIAL_TOKEN.
You may also set these variables in a .env file in the directory from which you are running Truthbrush.
CLI Usage
Usage: truthbrush [OPTIONS] COMMAND [ARGS]...
Options:
--help Show this message and exit.
Commands:
search Search for users, statuses or hashtags.
statuses Pull a user's statuses.
suggestions Pull the list of suggested users.
tags Pull trendy tags.
trends Pull trendy Truths.
ads Pull ads.
user Pull a user's metadata.
likes Pull the list of users who liked a post
comments Pull the list of oldest comments on a post
groupposts Pull posts from a groups's timeline
grouptags Pull trending group tags.
grouptrends Pull trending groups.
groupsuggestions Pull list of suggested groups.
Search for users, statuses, groups, or hashtags
truthbrush search --searchtype [accounts|statuses|hashtags|groups] QUERY
Pull all statuses (posts) from a user
truthbrush statuses HANDLE
Pull "People to Follow" (suggested) users
truthbrush suggestions
Pull trendy tags
truthbrush tags
Pull ads
truthbrush ads
Pull all of a user's metadata
truthbrush user HANDLE
Pull the list of users who liked a post
truthbrush likes POST --includeall TOP_NUM
Pull the list of oldest comments on a post
truthbrush comments POST --includeall --onlyfirst TOP_NUM
Pull trending group tags
truthbrush grouptags
Pull trending groups
truthbrush grouptrends
Pull list of suggested groups
truthbrush groupsuggestions
Pull posts from a group's timeline
truthbrush groupposts GROUP_ID
Contributing
Contributions are encouraged! For small bug fixes and minor improvements, feel free to just open a PR. For larger changes, please open an issue first so that other contributors can discuss your plan, avoid duplicated work, and ensure it aligns with the goals of the project. Be sure to also follow the code of conduct. Thanks!
Development setup (ensure you have Poetry installed):
poetry install
poetry shell
truthbrush --help # will use your local copy of truthbrush
To run the tests:
pytest
# optionally run tests with verbose logging outputs:
pytest --log-cli-level=DEBUG -s
Please format your code with black:
black .
Project details
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file truthbrush-0.2.5.tar.gz.
File metadata
- Download URL: truthbrush-0.2.5.tar.gz
- Upload date:
- Size: 13.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5e85bb8352a4f379572ccabcc4c506ce18877bc8f7166d41bb51cf2c75a59065
|
|
| MD5 |
ecf47eaa01f8792d3f4ceeec3aeb6a1a
|
|
| BLAKE2b-256 |
19b1789b1cd1c927b550e06b00a69df897cbac1d344d57a9d095fa64ad07b65f
|
Provenance
The following attestation bundles were made for truthbrush-0.2.5.tar.gz:
Publisher:
publish-to-pypi.yml on stanfordio/truthbrush
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
truthbrush-0.2.5.tar.gz -
Subject digest:
5e85bb8352a4f379572ccabcc4c506ce18877bc8f7166d41bb51cf2c75a59065 - Sigstore transparency entry: 893571534
- Sigstore integration time:
-
Permalink:
stanfordio/truthbrush@6ddd7d2ba8f10a16e79d09e1e5de538293de7f6f -
Branch / Tag:
refs/tags/v0.2.5 - Owner: https://github.com/stanfordio
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@6ddd7d2ba8f10a16e79d09e1e5de538293de7f6f -
Trigger Event:
release
-
Statement type:
File details
Details for the file truthbrush-0.2.5-py3-none-any.whl.
File metadata
- Download URL: truthbrush-0.2.5-py3-none-any.whl
- Upload date:
- Size: 13.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0bcf7393c822e91e5aeef29e242631e1ef1b4def85293e45992db335cd456506
|
|
| MD5 |
86537b0bc35f44705ab3f7355a76cc1e
|
|
| BLAKE2b-256 |
ca921959f2025241dc46c40466851eb138cc802fcbaec65a1a927c8f34eaa7b7
|
Provenance
The following attestation bundles were made for truthbrush-0.2.5-py3-none-any.whl:
Publisher:
publish-to-pypi.yml on stanfordio/truthbrush
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
truthbrush-0.2.5-py3-none-any.whl -
Subject digest:
0bcf7393c822e91e5aeef29e242631e1ef1b4def85293e45992db335cd456506 - Sigstore transparency entry: 893571596
- Sigstore integration time:
-
Permalink:
stanfordio/truthbrush@6ddd7d2ba8f10a16e79d09e1e5de538293de7f6f -
Branch / Tag:
refs/tags/v0.2.5 - Owner: https://github.com/stanfordio
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@6ddd7d2ba8f10a16e79d09e1e5de538293de7f6f -
Trigger Event:
release
-
Statement type: