# 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-downloadDb.js` Runs a full download of all users listed in the db.json of the archive (the provided `--path`). If db.json is not present, one will be created. Args: - `--path={/path/to/your/archive}` - `--threads={#}` - `--args={gallery-dl args}` Example: - `node run-downloadDb.js --path=/mnt/data/archive --threads=3 --args="-r 2.5M"` will run a full download (`/media` followed by `/search` starting from the oldest pulled file from `/media`) of all the users in the `/mnt/data/archive/db.json` file, limiting concurrent download threads to 3. It will pass the additional args `-r 2.5M --no-skip` to the gallery-dl bin being executed; `-r 2.5M --no-skip` corresponds to limiting the download rate to 2.5M and downloading all files without skipping (for the sake of example). ### `run-downloadUsers.js` Adds new user(s) to the db and initiate a full download similar to `run-downloadDb.js`. If db.json is not present, one will be created. Args: - `--path={/path/to/your/archive}` - `--users={comma,separated,userlist}` - `--threads={#}` ### `run-convertDb.js` Converts `db.json` to the latest version. See `./lib/schema.js` for full db.json schema. Args: - `--path={/path/to/your/archive}` Historical Versions: - v0: simple array of users with `user`, `lastUpdated`, `lastError` fields - v1 (**CURRENT**): object with `version` and `userList` fields, `userList` containing key-value entries where the key is the username, the value is an informational object regarding that username. ## 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. See [gallery-dl CLI options](https://github.com/mikf/gallery-dl/blob/master/docs/options.md#selection-options) for reference. Note that these aren't currently checked for duplicates that may be used by this repo. ## TODO ### `run-renameUser.js` Should rename an existing user in the db, optionally renaming their existing archive and its contents if `--full=true`. Args: - `--from={'username'}` - `--to={'username'}` - `--full={true|false}` - `--path={/path/to/your/archive}` - `--args={gallery-dl args}`