mProjectsCode / obsidian-media-db-plugin

A plugin that can query multiple APIs for movies, series, anime, games, music and wiki articles, and import them into your vault.
GNU General Public License v3.0
254 stars 31 forks source link
anime games movies obsidian obsidian-md obsidian-plugin

Obsidian Media DB Plugin

A plugin that can query multiple APIs for movies, series, anime, manga, games, music and wiki articles, and import them into your vault.

Features

Search by Title

Search a movie, series, anime, game, music release or wiki article by its name across multiple APIs.

Search by ID

Allows you to search by an ID that varies from API to API. Concrete information on this feature can be found in the description of the individual APIs.

Templates

The plugin allows you to set a template note that gets added to the end of any note created by this plugin.
The plugin also offers simple "template tgs". E.g. if the template includes {{ title }}, it will be replaced by the title of the movie, show or game.
Note that "template tags" are surrounded with two curly braces and that the spaces inside the curly braces are important.

For arrays there are two special ways of displaying them.

Available variables that can be used in template tags are the same variables from the metadata of the note.

I also published my own templates here.

Metadata field customization

Allows you to rename the metadata fields this plugin generates through mappings.

A mapping has to follow this syntax [origional property name] -> [new property name]. Multiple mappings are separated by a new line. So e.g.:

title -> name
year -> releaseYear

Bulk Import

The plugin allows you to import your preexisting media collection and upgrade them to Media DB entries.

Prerequisites

The preexisting media notes must be inside a folder in your vault. For the plugin to be able to query them they need one metadata field that is used as the title the piece of media is searched by. This can be achieved by for example using a csv import plugin to import an existing list from outside of obsidian.

Importing

To start the import process, right-click on the folder and select the Import folder as Media DB entries option. Then specify the API to search, if the current note content and metadata should be appended to the Media DB entry and the name of the metadata field that contains the title of the piece of media.

Then the plugin will go through every file in the folder and prompt you to select from the search results.

Post import

After all files have been imported or the import was canceled, you will find the new entries as well as an error report that contains any errors or skipped/canceled files in the folder specified in the setting of the plugin.

How to install

The plugin is now released, so it can be installed directly through obsidian's plugin installer.

Alternatively, you can manually download the zip archive from the latest release here on GitHub.
After downloading, extract the archive into the .obsidian/plugins folder in your vault.

The folder structure should look like this:

[path to your vault]
|_ .obsidian
   |_ plugins
      |_ obsidian-media-db-plugin
         |_ main.js
         |_ manifest.json
         |_ styles.css

How to use

(pictures are coming)

Once you have installed this plugin, you will find a database icon in the left ribbon.
When using this or the Add new Media DB entry command, a popup will open.
Here you can enter the title of what you want to search for and then select in which APIs to search.

After clicking search, a new popup will open prompting you to select from the search results.
Now you select the result you want and the plugin will cast it's magic and create a new note in your vault, that contains the metadata of the selected search result.

Currently supported media types

Currently supported APIs:

Name Description Supported formats Authentification Rate limiting SFW filter support
Jikan Jikan is an API that uses My Anime List and offers metadata for anime. series, movies, specials, OVAs, manga, manwha, novels No 60 per minute and 3 per second Yes
OMDb OMDb is an API that offers metadata for movie, series and games. series, movies, games Yes, you can get a free key here here 1000 per day No
MusicBrainz MusicBrainz is an API that offers information about music releases. music releases No 50 per second No
Wikipedia The Wikipedia API allows access to all Wikipedia articles. wiki articles No None No
Steam The Steam API offers information on all steam games. games No 10000 per day No
Open Library The OpenLibrary API offers metadata for books books No Cover access is rate-limited when not using CoverID or OLID by max 100 requests/IP every 5 minutes. This plugin uses OLID so there shouldn't be a rate limit. No
Moby Games The Moby Games API offers metadata for games for all platforms games Yes, by making an account here API requests are limited to 360 per hour (one every ten seconds). In addition, requests should be made no more frequently than one per second. No

Notes

Search by ID

Problems, unexpected behavior or improvement suggestions?

You are more than welcome to open an issue on GitHub.

Contributions

Thank you for wanting to contribute to this project.

Contributions are always welcome. If you have an idea, feel free to open a feature request under the issue tab or even create a pull request.

Credits

Credits go to: