Mod portal API: Difference between revisions
No edit summary |
(Add description of license field) |
||
(32 intermediate revisions by 10 users not shown) | |||
Line 1: | Line 1: | ||
<div align="center" class="stub">'''Category:''' [[Factorio_HTTP_API_usage_guidelines#Internal|Internal API]]</div> | |||
The Mod Portal API is used to both browse and download all mods available on the [https://mods.factorio.com/ official Factorio mod portal]. Using the API does not require any kind of authentication or account information and can be viewed simply by following the URLs below in any web browser. | The Mod Portal API is used to both browse and download all mods available on the [https://mods.factorio.com/ official Factorio mod portal]. Using the API does not require any kind of authentication or account information and can be viewed simply by following the URLs below in any web browser. | ||
Line 8: | Line 8: | ||
<code>https://mods.factorio.com/api/mods/{name}</code> | <code>https://mods.factorio.com/api/mods/{name}</code> | ||
To get even more information about a mod, you can use the following URL. | |||
<code>https://mods.factorio.com/api/mods/{name}/full</code> | |||
== Endpoints == | == Endpoints == | ||
Line 16: | Line 20: | ||
{| class="wikitable" | {| class="wikitable" | ||
! Key !! Description | ! Key !! Values !! Description | ||
|- | |- | ||
| | | hide_deprecated || {boolean} || Only return non-deprecated mods. | ||
|- | |- | ||
| | | page ||{an integer}||Page number you would like to show. Makes it so you can see a certain part of the list without getting detail on all | ||
|- | |- | ||
| | | page_size ||{an integer or 'max'}||The amount of results to show in your search | ||
|- | |- | ||
| | | sort || {enum, one of name, created_at or updated_at} || Sort results by this property. Defaults to name when not defined. Ignored for <code>page_size=max</code> queries. | ||
|- | |- | ||
| | | sort_order || {enum, one of asc or desc} || Sort results ascending or descending. Defaults to descending when not defined. Ignored for <code>page_size=max</code> queries. | ||
|- | |- | ||
| | | namelist || {array of strings} || Return only mods that match the given names. Response will include <code>releases</code> instead of <code>latest_release</code>. | ||
|- | |||
| version || {enum, one of 0.13, 0.14, 0.15, 0.16, 0.17, 0.18, 1.0 or 1.1} || Only return non-deprecated mods compatible with this Factorio version | |||
|} | |} | ||
Line 36: | Line 42: | ||
=== /api/mods/{mod_name} === | === /api/mods/{mod_name} === | ||
Return short information of a specific mod. | |||
=== /api/ | See [[#Result Entry]], "Short" column. | ||
=== /api/mods/{mod_name}/full === | |||
Returns more information of a mod. | |||
See [[#Result Entry]], "Full" column. | |||
== JSON Object Types == | == JSON Object Types == | ||
Line 84: | Line 96: | ||
=== Result Entry === | === Result Entry === | ||
Fields returned by the api/mods endpoint are marked with a check (✓) in the " | Fields returned by the api/mods endpoint are marked with a check (✓) in the "api/mods endpoint" column, those returned by the api/mods/{name} endpoint are marked with a check in the "Short" column and those returned by the api/mods/{name}/full endpoint are marked in the "Full" column. Fields may be absent if there is no data. | ||
{| class="wikitable" | {| class="wikitable" | ||
! Key !! Type !!+ style='writing-mode:vertical-lr;vertical-align:bottom;font-size:90%' | Short !!+ style='writing-mode:vertical-lr;vertical-align:bottom;font-size:90%' | Full !! Description | ! Key !! Type !!+ style='writing-mode:vertical-lr;vertical-align:bottom;font-size:90%' | api/mods endpoint !!+ style='writing-mode:vertical-lr;vertical-align:bottom;font-size:90%' | Short !!+ style='writing-mode:vertical-lr;vertical-align:bottom;font-size:90%' | Full !! Description | ||
|- | |- | ||
| | | downloads_count || Integer || ✓ || ✓ || ✓ | ||
| Number of downloads. | | Number of downloads. | ||
|- | |- | ||
| | | latest_release || [[#Releases|Release]]? || ✓ || || | ||
| The | | The latest version of the mod available for download. Absent when the <code>namelist</code> [[#/api/mods|parameter]] is used. | ||
|- | |- | ||
| | | name || String || ✓ || ✓ || ✓ | ||
| | | The mod's machine-readable ID string. | ||
|- | |- | ||
| | | owner || String || ✓ || ✓ || ✓ | ||
| | | The Factorio username of the mod's author. | ||
|- | |- | ||
| | | releases || [[#Releases|Release]][] || ✓* || ✓ || ✓ | ||
| | | A list of different versions of the mod available for download. See [[#Releases]]. *Only when using <code>namelist</code> [[#/api/mods|parameter]]. | ||
|- | |- | ||
| | | summary || String || ✓ || ✓ || ✓ | ||
| A | | A shorter mod description. | ||
|- | |- | ||
| | | title || String || ✓ || ✓ || ✓ | ||
| The | | The mod's human-readable name. | ||
|- | |- | ||
| | | category || [[#Tags|Tag]]? || ✓ || ✓ || ✓ | ||
| A | | A single tag describing the mod. See [[#Tags]]. | ||
|- | |- | ||
| | | thumbnail || String(relative URL) || || ✓ || ✓ | ||
| The mod | | The relative path to the thumbnail of the mod. For mods that have no thumbnail it may be absent or default to <code>"/assets/.thumb.png"</code>. Prepend "assets-mod.factorio.com". | ||
|- | |- | ||
| | | changelog || String || || || ✓ | ||
| A | | A string describing the recent changes to a mod. | ||
|- | |||
| created_at || String(ISO 8601) || || || ✓ | |||
| ISO 6501 for when the mod was created. | |||
|- | |- | ||
| | | description || String || || || ✓ | ||
| A | | A longer description of the mod, in text only format. | ||
|- | |- | ||
| | | github_path || String || || || ✓ | ||
| | | A link to the mod's github project page, just prepend "github.com/". Can be blank (""). | ||
|- | |- | ||
| | | homepage || String || || || ✓ | ||
| | | Usually a URL to the mod's main project page, but can be any string. | ||
|- | |- | ||
| | | tag || [[#Tags|Tag]][] || || || ✓ | ||
| A list of tag objects that categorize the mod. See [[#Tags]]. | | A list of tag objects that categorize the mod. See [[#Tags]]. | ||
|- | |- | ||
| | | license || [[#License]][] || || || ✓ | ||
| The license that applies to the mod. See [[#License]]. | |||
| | |||
| | |||
| The | |||
|- | |- | ||
|} | |} | ||
=== | === Releases === | ||
Only difference here between the api/mods/{name} endpoint and the api/mods/{name}/full endpoint is that the full one includes an array of dependencies in the info_json object. | |||
{| class="wikitable" | {| class="wikitable" | ||
! | ! Key !! Type !! Description | ||
|- | |- | ||
| download_url || String | |||
| Path to download for a mod. starts with "/download" and does not include a full url. See [[#Downloading Mods]] | |||
|- | |- | ||
| | | file_name || String | ||
| The file name of the release. Always seems to follow the pattern "{name}_{version}.zip" | |||
|- | |- | ||
| | | info_json || Object | ||
| A copy of the mod's info.json file, only contains factorio_version in short version, also contains an array of dependencies in full version | |||
|- | |||
| released_at || String(ISO 8601) | |||
| ISO 6501 for when the mod was released. | |||
|- | |- | ||
| | | version || String | ||
| The version string of this mod release. Used to determine dependencies. | |||
|- | |- | ||
| | | sha1 || String | ||
| | | The sha1 key for the file | ||
|- | |||
|- | |||
|} | |} | ||
Line 233: | Line 213: | ||
| 14 || t || utility || Utility || Helps with certain things the player is doing. | | 14 || t || utility || Utility || Helps with certain things the player is doing. | ||
|- | |- | ||
| 15 || t || balancing || Balancing || | | 15 || t || balancing || Balancing || Makes the game much more fair | ||
|- | |- | ||
| 17 || t || enemies || Enemies || | | 17 || t || enemies || Enemies || Adds more enemies for more challange | ||
|- | |- | ||
| 16 || t || weapons || Weapons || | | 16 || t || weapons || Weapons || Adds more weapons to annihilate the enemy | ||
|- | |- | ||
| 18 || t || armor || Armor || Armors or armor equipment related. | | 18 || t || armor || Armor || Armors or armor equipment related. | ||
Line 245: | Line 225: | ||
| 20 || t || logistics-network || Logistics Network || Related to roboports and logistic robots | | 20 || t || logistics-network || Logistics Network || Related to roboports and logistic robots | ||
|- | |- | ||
| 21 || t || storage || Storage || | | 21 || t || storage || Storage || Allows more ways to be able to store items | ||
|- | |- | ||
| 22 || t || power-production || Power Production || | | 22 || t || power-production || Power Production || Allows more ways to create mass amounts of energy | ||
|- | |- | ||
| 23 || t || manufacture || Manufacture || Furnaces, assembling machines, production chains | | 23 || t || manufacture || Manufacture || Furnaces, assembling machines, production chains | ||
|- | |- | ||
| 24 || t || blueprints || Blueprints || | | 24 || t || blueprints || Blueprints || | ||
|- | |- | ||
| 25 || t || cheats || Cheats || | | 25 || t || cheats || Cheats || Well, they let you cheat | ||
|- | |- | ||
| 26 || t || defense || Defense || | | 26 || t || defense || Defense || Mods that add the ability to protect your base more | ||
|- | |- | ||
| 27 || t || mining || Mining || | | 27 || t || mining || Mining || Mods that provide better or new ways of mining resources | ||
|- | |- | ||
| 28 || t || info || Info || Mods that provide additional information to the player | | 28 || t || info || Info || Mods that provide additional information to the player | ||
|- | |- | ||
| 29 || t || trains || Trains || | | 29 || t || trains || Trains || Related to trains | ||
|} | |} | ||
=== | === License === | ||
{| class="wikitable" | {| class="wikitable" | ||
! Key !! Type !! Description | ! Key !! Type !! Description | ||
|- | |- | ||
| | | description || String || A short description of the license. | ||
|- | |- | ||
| | | id || String || The unique id of the license. | ||
|- | |- | ||
| | | name || String || The internal name of the license. | ||
|- | |- | ||
| | | title || String || The human-readable title of the license. | ||
|- | |- | ||
| | | url || String || Usually a URL to the full license text, but can be any string. | ||
|} | |} | ||
=== | === Error === | ||
{| class="wikitable" | {| class="wikitable" | ||
! Key !! Type !! Description | ! Key !! Type !! Description | ||
|- | |- | ||
| | | detail || String || | ||
|} | |} | ||
== Downloading Mods == | |||
=== | |||
You can get the full url by appending the download_url to mods.factorio.com, but if you're not authenticated, you will be redirected to mods.factorio.com/login. Logging in to that would give you access to the file. Fortunately, there's a better way to do this. Simply adding username and token parameters to the download url will prevent the redirecting and let you download the file immediately. The token can be acquired from a json file called "player-data.json", located in the User Data directory (see [[Application_directory#User_data_directory]]). You can also get the token by using the [[Web_authentication_API | Web Authentication API]]. | |||
{ | Example usage: | ||
https://mods.factorio.com/{download_url}?username={username}&token={token} | |||
{{Languages}}[[Category:Technical]] | {{Languages}}[[Category:Technical]] |
Latest revision as of 21:50, 13 December 2022
The Mod Portal API is used to both browse and download all mods available on the official Factorio mod portal. Using the API does not require any kind of authentication or account information and can be viewed simply by following the URLs below in any web browser.
https://mods.factorio.com/api/mods
More detailed information about a particular mod can be obtained by retrieving the following URL, where {name} is the mod's name field in the result object.
https://mods.factorio.com/api/mods/{name}
To get even more information about a mod, you can use the following URL.
https://mods.factorio.com/api/mods/{name}/full
Endpoints
/api/mods
GET Parameters:
Key | Values | Description |
---|---|---|
hide_deprecated | {boolean} | Only return non-deprecated mods. |
page | {an integer} | Page number you would like to show. Makes it so you can see a certain part of the list without getting detail on all |
page_size | {an integer or 'max'} | The amount of results to show in your search |
sort | {enum, one of name, created_at or updated_at} | Sort results by this property. Defaults to name when not defined. Ignored for page_size=max queries.
|
sort_order | {enum, one of asc or desc} | Sort results ascending or descending. Defaults to descending when not defined. Ignored for page_size=max queries.
|
namelist | {array of strings} | Return only mods that match the given names. Response will include releases instead of latest_release .
|
version | {enum, one of 0.13, 0.14, 0.15, 0.16, 0.17, 0.18, 1.0 or 1.1} | Only return non-deprecated mods compatible with this Factorio version |
Returns #Mod List Response
/api/mods/{mod_name}
Return short information of a specific mod.
See #Result Entry, "Short" column.
/api/mods/{mod_name}/full
Returns more information of a mod.
See #Result Entry, "Full" column.
JSON Object Types
Mod List Response
Key | Type | Description |
---|---|---|
pagination | Pagination | See #Pagination |
results | Result[] | A list of mods, matching any filters you specified. |
Pagination
Key | Type | Description |
---|---|---|
count | Integer | Total number of mods that match your specified filters. |
links | Links | Utility links to mod portal api requests, preserving all filters and search queries. |
page | Integer | The current page number. |
page_count | Integer | The total number of pages returned. |
page_size | Integer | The number of results per page. |
Pagination Links
Key | Type | Description |
---|---|---|
first | String(URL) | URL to the first page of the results, or null if you're already on the first page. |
prev | String(URL) | URL to the previous page of the results, or null if you're already on the first page. |
next | String(URL) | URL to the next page of the results, or null if you're already on the last page. |
last | String(URL) | URL to the last page of the results, or null if you're already on the last page. |
Result Entry
Fields returned by the api/mods endpoint are marked with a check (✓) in the "api/mods endpoint" column, those returned by the api/mods/{name} endpoint are marked with a check in the "Short" column and those returned by the api/mods/{name}/full endpoint are marked in the "Full" column. Fields may be absent if there is no data.
Key | Type | api/mods endpoint | Short | Full | Description |
---|---|---|---|---|---|
downloads_count | Integer | ✓ | ✓ | ✓ | Number of downloads. |
latest_release | Release? | ✓ | The latest version of the mod available for download. Absent when the namelist parameter is used.
| ||
name | String | ✓ | ✓ | ✓ | The mod's machine-readable ID string. |
owner | String | ✓ | ✓ | ✓ | The Factorio username of the mod's author. |
releases | Release[] | ✓* | ✓ | ✓ | A list of different versions of the mod available for download. See #Releases. *Only when using namelist parameter.
|
summary | String | ✓ | ✓ | ✓ | A shorter mod description. |
title | String | ✓ | ✓ | ✓ | The mod's human-readable name. |
category | Tag? | ✓ | ✓ | ✓ | A single tag describing the mod. See #Tags. |
thumbnail | String(relative URL) | ✓ | ✓ | The relative path to the thumbnail of the mod. For mods that have no thumbnail it may be absent or default to "/assets/.thumb.png" . Prepend "assets-mod.factorio.com".
| |
changelog | String | ✓ | A string describing the recent changes to a mod. | ||
created_at | String(ISO 8601) | ✓ | ISO 6501 for when the mod was created. | ||
description | String | ✓ | A longer description of the mod, in text only format. | ||
github_path | String | ✓ | A link to the mod's github project page, just prepend "github.com/". Can be blank (""). | ||
homepage | String | ✓ | Usually a URL to the mod's main project page, but can be any string. | ||
tag | Tag[] | ✓ | A list of tag objects that categorize the mod. See #Tags. | ||
license | #License[] | ✓ | The license that applies to the mod. See #License. |
Releases
Only difference here between the api/mods/{name} endpoint and the api/mods/{name}/full endpoint is that the full one includes an array of dependencies in the info_json object.
Key | Type | Description |
---|---|---|
download_url | String | Path to download for a mod. starts with "/download" and does not include a full url. See #Downloading Mods |
file_name | String | The file name of the release. Always seems to follow the pattern "{name}_{version}.zip" |
info_json | Object | A copy of the mod's info.json file, only contains factorio_version in short version, also contains an array of dependencies in full version |
released_at | String(ISO 8601) | ISO 6501 for when the mod was released. |
version | String | The version string of this mod release. Used to determine dependencies. |
sha1 | String | The sha1 key for the file |
Tags
Key | Type | Description |
---|---|---|
id | Integer | A numerical ID unique to this tag. |
name | String | An all lower-case string used to identify this tag internally. |
title | String | The tag's human-readable tag name. |
description | String | A short description for the tag. |
type | String |
Currently, there are only a fixed number of tags available, these include:
id | type | name | title | description |
---|---|---|---|---|
1 | t | general | General | Mods that cannot be sorted into other categories |
2 | t | non-game-changing | Non-Game-Changing | Changes only look&feel. New graphics, new sounds, ... such things. |
3 | t | helper-mods | Helper Mods | These mods are not game-changing, but enhance the gameplay by helping you with useful functions. Mods like showing the current game-time, keep track over your resources, rail-laying... |
6 | t | big-mods | Big Mods | Too big and/or changes too much of the game to be fit anywhere else |
12 | t | transportation | Transportation | Player transport |
13 | t | logistics | Logistics | Transport of materials |
14 | t | utility | Utility | Helps with certain things the player is doing. |
15 | t | balancing | Balancing | Makes the game much more fair |
17 | t | enemies | Enemies | Adds more enemies for more challange |
16 | t | weapons | Weapons | Adds more weapons to annihilate the enemy |
18 | t | armor | Armor | Armors or armor equipment related. |
19 | t | oil | Oil | Things related to oil related manufacture |
20 | t | logistics-network | Logistics Network | Related to roboports and logistic robots |
21 | t | storage | Storage | Allows more ways to be able to store items |
22 | t | power-production | Power Production | Allows more ways to create mass amounts of energy |
23 | t | manufacture | Manufacture | Furnaces, assembling machines, production chains |
24 | t | blueprints | Blueprints | |
25 | t | cheats | Cheats | Well, they let you cheat |
26 | t | defense | Defense | Mods that add the ability to protect your base more |
27 | t | mining | Mining | Mods that provide better or new ways of mining resources |
28 | t | info | Info | Mods that provide additional information to the player |
29 | t | trains | Trains | Related to trains |
License
Key | Type | Description |
---|---|---|
description | String | A short description of the license. |
id | String | The unique id of the license. |
name | String | The internal name of the license. |
title | String | The human-readable title of the license. |
url | String | Usually a URL to the full license text, but can be any string. |
Error
Key | Type | Description |
---|---|---|
detail | String |
Downloading Mods
You can get the full url by appending the download_url to mods.factorio.com, but if you're not authenticated, you will be redirected to mods.factorio.com/login. Logging in to that would give you access to the file. Fortunately, there's a better way to do this. Simply adding username and token parameters to the download url will prevent the redirecting and let you download the file immediately. The token can be acquired from a json file called "player-data.json", located in the User Data directory (see Application_directory#User_data_directory). You can also get the token by using the Web Authentication API.
Example usage: https://mods.factorio.com/{download_url}?username={username}&token={token}