--- title: "ModArchive" output: rmarkdown::html_vignette vignette: > %\VignetteIndexEntry{ModArchive} %\VignetteEngine{knitr::rmarkdown} %\VignetteEncoding{UTF-8} --- ```{r, include = FALSE} knitr::opts_chunk$set( collapse = TRUE, comment = "#>" ) ``` [Modarchive](https://modarchive.org/) is a decades old archive containing thousands of module files. It is maintained and operated by a team of volunteers, and is funded with donations. It contains a diversity of module file formats and music genres. ## ModArchive tools The ModArchive offers an application programming interface (API), for which the `openmpt` package offers several wrappers in R. For many of these functions you need an API key (see below) If you know the module's database ID, you can download it (without an API key) using ```{r modarchive-download} library(openmpt) unreal <- modarchive_download(60395) unreal ``` Using the module ID you can also obtain meta-information from ModArchive for that module. ```{r modarchive-info} if (modarchive_api() != "") { info <- modarchive_info(60395) info$genretext } ``` If you don't know the module ID, you can search the archive through different entry points: * `modarchive_search_mod()`: search for texts in different fields and filter the results with specific criteria * `modarchive_search_genre()`: browse modules for a specific genre and filter the results with specific criteria * `modarchive_search_hash()`: search for a specific hash code * `modarchive_view_by()`: create different views of lists of modules ## ModArchive API key In order to keep traffic to the ModArchive servers in fair bounds, an API key is needed to make use of the features offered by the ModArchive toolbox. These keys are handed out and maintained by the ModArchive crew. In order to apply for a key, you first need to register at the [ModArchive Forums](https://modarchive.org/forums/). Then follow the instructions provided in [this topic](https://modarchive.org/forums/index.php?topic=1950.0) on the forum. Note that there are [different access levels](https://modarchive.org/index.php?xml-api), where the access levels determine which features are available to you. If ModArchive features wrapped in the `openmpt` package don't work, you might need a higher access level. Most wrappers (like `modarchive_search_mod()`) have an argument named `api`. There you can pass your key directly as argument. You can also set it as an environmental variable: `Sys.setenv(MODARCHIVE_API = "")`. You can also set it as a session option: `options(modarchive_api = "")`. By setting it as either an option or an environmental variable, you don't have to pass it as an argument with each call. It is automatically obtained with `modarchive_api()`. Each API key comes with a cap on the number of monthly requests you can make to the server. You can check how many requests you have and can make each month with your key with `modarchive_requests()`. Below you can how many requests where made with the key used for developing this package at the time this vignette was rendered (only if the machine rendering this vignette has registered an API key). ```{r modarchive-requests} if (modarchive_api() != "") modarchive_requests() ``` If you want to extract large quantities of files it is advised to use (torrent files)[http://modarchive.textfiles.com/], which distributes the traffic across multiple hosts. ## Other online resources Currently, the only alternative for ModArchive, supported by the `openmpt` package is [modland](https://modland.com/). It offers less features compared to ModArchive, yet it has a large collection of over 400,000 files and counting. You can use `modland_search()` and `modland_download()` to search and download files on and from modland, respectively. The good news here is that you don't need an API key.