- Jack H. Culbert
- [email protected]
- https://orcid.org/0009-0000-1581-4021
You can find the associated technical report here.
Please reference this paper if you use this tool in research or your own projects.
Both the author and GESIS are not affiliated, associated, authorized, endorsed by, or in any way officially connected with 4chan, or any of its subsidiaries or its affiliates. The official 4chan website can be found at 4chan.org.
The names 4chan as well as related names, marks, emblems and images are registered trademarks of their respective owners.
Please be aware 4chan may serve offensive and/or illegal images and texts, and it is the sole responsibility of the user to vet and remove material that may be illegal in their jurisdiction. The author and GESIS shall have unlimited liability for damages resulting from injury to life, limb or health and in the event of liability under the German Product Liability Act (Act on Liability for Defective Products). This shall also apply in the event of a breach of so-called cardinal obligations, i.e. obligations the breach of which would jeopardize the purpose of the contract and the performance of which the user as contracting party may therefore reasonably rely on. Otherwise, the author and GESIS shall only be liable for intent and gross negligence.
To select which boards to collect the textual data from, use the -b
parameter to pass requester.py a list containing the strings of the short form of the board name e.g. python src/requester.py -b adv toy sci
to include only these boards.
To exclude a selection of boards from the tool, pass a list as above with the -b
parameter and also include a -e
.
For more information please run python src/requester.py -h
Run python src/requester.py
from the root directory after installing the requirements found in src/requirements.txt
, e.g. with pip install -r src/requirements.txt
.
Tested on Python 3.10.2 and 3.11.4
If it is desired to pass arguments, edit the CMD found in src/Dockerfile
, passing in arguments as strings but retaining the -d
argument, e.g:
CMD ["python", "/app/requester.py", "-d", "-b", "adv", "toy", "sci"]
Run docker-compose up
from the root directory.
Tested on Docker Version 23.0.5, Docker Compose v2.17.3
- Two directories are created for logs, and the data (saves/"the current date")
- The requester will first query the 4chan API to find the current list of boards, if present the include or exclude boards are selected or removed from the list.
- For every board resulting from this process, two subdirectories folder will be created in the data folder, one for storing the threads and one for the thread on each board.
- The requester then goes through each board to find a list of threads on each board.
- These are saved to the threads_on_boards folder
- The requester then requests the posts on each board.
- The data is saved to a subfolder of threads, with a name consisting of the thread id and the time of first observance.
- The loop repeats by checking each board for new and dead threads, then querying the new and live threads.
The requester attempts to pick up from previous runs by observing the state of the saves directory. If this is deleted it will act as from fresh.
Debug logs are set to capture each API call and are as such, very detailed (approx 80 times as large as info). By default the info log is output to terminal.
Please ensure you follow the 4Chan API Rules and Terms of Service found here.
At time of writing these are:
- Do not make more than one request per second.
- Thread updating should be set to a minimum of 10 seconds, preferably higher.
- Use If-Modified-Since when doing your requests.
- Make API requests using the same protocol as the app. Only use SSL when a user is accessing your app over HTTPS.
- You may not use "4chan" in the title of your application, product, or service.
- You may not use the 4chan name, logo, or brand to promote your application, product, or service.
- You must disclose the source of the information shown by your application, product, or service as 4chan, and provide a link.
- You may not market your application, product, or service as being "official" in any way.
- You may not clone 4chan or its existing features/functionality. Example: Don't suck down our JSON, host it elsewhere, and throw ads around it.
- These terms are subject to change without notice.
Thank you very much to the team behind the 4Chan API!