code for my very abstruse python-based static site generator
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
trémeur f758ec46ad Add links to singles pages and to fedi posts where applicable 10 months ago
build Change ratings terminology, better emoji support 1 year ago
originalsmeta Add links to singles pages and to fedi posts where applicable 10 months ago
texts Add files 2 years ago
translationsmeta Add files 2 years ago
.gitignore Add single pages for linking to 1 year ago
COPYING Add files 2 years ago
README.org Add links to singles pages and to fedi posts where applicable 10 months ago
build.sh Link to singles from stats pages 1 year ago
characters.py Sort fics properly 1 year ago
commentpage.py Update email address 1 year ago
events.py Sort fics properly 1 year ago
fandoms.py Sort fics properly 1 year ago
feed.py Replace slashes with × in ship names like any good old-school weeb 10 months ago
generate.py Add single pages for linking to 1 year ago
headerfooter.py Add theme colour 11 months ago
indexgen.py Add link to the code from index page, update readme 1 year ago
makeheader.py Add links to singles pages and to fedi posts where applicable 10 months ago
masterlist.py Sort fics properly 1 year ago
ships.py Replace slashes with × in ship names like any good old-school weeb 10 months ago
single.py Generate single pages for locked fics, link to single pages from RSS feed, use local CSS file in local build 1 year ago
sortfics.sh Makes more sense to overwrite output files 1 year ago
statsgen.py Replace slashes with × in ship names like any good old-school weeb 10 months ago
verifygen.py Add age verification gate and some noscript fallbacks 2 years ago
wordcount.py Add page for FF fics by wordcount, deal with spoilers in RSS feed, change wording in a few places 2 years ago

README.org

Code for my personal fic archive

Preliminaries

This is very much set up for my own use, but the code is public so others can see how this works and build similar things for themselves, if they like.

build.sh generates files in the build directory and uploads them to the remote using rclone. To build locally for testing, run python3 generate.py local, which generates links that point straight to index.html instead of the containing directory.

This is for my personal use and definitely wont work as is for other people, but feel free to dig around in the files. I am an amateur and I almost certainly dont follow best practices in any respect.

Fic metadata lives in originalsmeta/ following the template, translation metadata in translationsmeta/; the filename for each is a unique 3-digit number. Fic files with the corresponding filenames live in texts (HTML, PDF, and EPUB are recognised in the script, which then moves them into build/files/ or build/secret/ according to metadata).

On the server my secret/ folder is protected using .htpasswd. In the current setup the comments are sent to my private Discord server using webhooks, so do modify the POST request in the comments pages if you dont want your own test comments being sent to my server, haha.

Requisites: rclone (just for uploading files to the server), Python 3.

My use case

  • most of my current fandoms are numbered parts of a bigger franchise
  • some of my fics have both English and French versions
  • I have a lot of juvenilia that I want to place behind a veneer of protection
  • some but not all of my fics are on AO3; HTML, PDF and EPUB formats exist for most, but this can be adjusted for individual entries as needed
  • whether commenting is enabled on a particular fic depends on a couple of factors

Future plans [3/6]

  • redirect to a consent page using local storage (h/t Fandom Coders)
  • pages for times and locations in FF fandoms
  • possibly a page for non-FF fandoms (as if I even care about these lol)
  • python-based browser for loading in fic metadata and grabbing stats (“what were my top ships in 2022” etc.) in progress
  • drabble wall
  • link to singles pages from headers? on the number?