Skip to content

theBreadCompany/pixivloader

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pixivloader

A CLI to communicate with pixiv.net

Disclaimer

This whole peace is provided as is, and I am not responsible for any damage or law breakings, i. e. damage to your hardware or consumption of questionable content.

Also, please do not overuse this. Pixiv has no financial benefit from this, and they somehow have to finance their servers, too...

Installation

Clone this repo via git clone https://github.com/theBreadCompany/pixivloader, enter it via cd pixivloader and build via swift build. You then have a handy binary at .build/debug/pixivloader that you can move to a location in your PATH.

You can find (pre)release binaries here.

Also for now, only the UI login reliably works, so I included the pixivauth subproject to login via the website and get a token to use with this script.

Documentation

generally:

USAGE: pixivloader <subcommand>

OPTIONS:
  -h, --help              Show help information.

SUBCOMMANDS:
  download                download illustrations
  bookmark                bookmark illustrations
  unbookmark              unbookmark illustrations
  follow                  follow users
  unfollow                unfollow users
  info                    print details about users and illustrations
  meta_update             update metadata of given images

See pixivloader help <subcommand> or furtherHelp.md for detailed help. You will be asked to provide either a token or you regular credentials on first login.

Examples

  • pixivloader auth -r <token> -> login with a token
  • pixivloader download -u nixeu -l 50 -d uwu -> downloads max. 50 illustrations of the user nixeu to the directory uwu
  • pixivloader info --illust 92167325-> print information about the illustration with the ID 92167325 (filenames are possible, too)
  • pixivloader bookmark uwu -> publicly bookmarks all illustrations in the directory uwu

Tips And Tricks

  • if your system has a easy-to-use index search (like macOS spotlight), you can combine this tool with it: you can use i.e. pixivloader download -s $(mdfind -interpret "girl scenery" -onlyin <dir1>) to download illustrations that are related to the ones returned by the search query, which itself searches for images with the tags girl and scenery in the directory <dir1>.
  • the script is not yet able to read the the source URL integrated in the image, meaning that you have to preserve the ID in the filename in order to keep it recognizable by the script

Tools

  • check.swift: a small script to check if a directory contains illustrations of another directory. Use with check <dir1> <dir2>, all matching illustrations from <dir2> that occur in <dir1> will be deleted. Compile with swiftc check.swift and place somewhere handy.

TODO

  • create tests
  • document the rest if needed
  • use ParsableCommands instead of options for the download subcommands
  • fix headless login with pw -> this has to be fixed
  • don't kill the entire config if one thing is missing -> important for future changes of the config
  • don't just crash when some trivial error like a rate limit ouccurs

Announcements

I'll release a repo of an iOS/macOS app using this API in a few weeks.

Credits

  • pixiv.net for their amazing platform
  • Apple for creating a powerful language that is really nice to learn and use