1
0
Fork 0
gallery-dl-archive-manager/README.md
2024-02-09 23:03:22 -05:00

44 lines
2.1 KiB
Markdown

# gallery-dl-archive-manager
Scripts to manage a (currently twitter only) archive using gallery-dl. Much of the code came from a need to augment pre-existing, outdated archives that were originally created from the `twittermediadownloader` browser extension.
## Config
This repo uses its own `config.json` in order to save media in the same format as `twittermediadownloader`. The scripts depend on the media being saved in this format.
## Scripts
### `node run-initDb.js --path={/path/to/your/archive} --args={gallery-dl args}`
Initializes a user database from existing folders. Useful if you have a pre-existing archive of users.
### `node run-downloadDb.js --path={/path/to/your/archive} --threads={#} --args={gallery-dl args}`
## Args
Standard args:
### `--path={/path/to/your/archive}`
The path to the archive. This is a parent directory with a list of child directories which correspond to users.
### `--threads={#}`
Max number of concurrent download threads. Only this number of concurrent gallery-dl download threads will run at a given time, other remaining users will be queued.
### `--args={gallery-dl args}`
Additional args to pass to gallery-dl. Note that these aren't currently checked for duplicates that may be used by this repo.
## TODO
### `run-addUsers.js --path={/path/to/your/archive} --users={string array of user(s)} --threads={#}`
Should add a new user to the db and initiate a full download similar to `run-downloadDb.js`
### `run-updateDb.js --path={/path/to/your/archive} --mode={search|media} --threads={#} --args={gallery-dl args}`
Should pull from the user database and update the archive without doing a full download.
- `--mode`
- `=search`: The DB should save with a lastUpdated field. This should be used as a date for the /search API. Preferred if it's been a long time since an update has happened for a user and/or the user has uploaded a significant amount of media since lastUpdated.
- `=media`: This will run /media and stop after hitting skipped files, as skipped files indicate hitting lastUpdated. Preferred in normal circumstances.