Introduction
Welcome to the LootLocker Admin API Documentation.
We do our best to keep this documentation up to date, but if you find any issues, please reach out to us at hello@lootlocker.io or join our Discord server.
Authentication
Initial Authentication Request
curl -X POST "https://api.lootlocker.io/admin/v1/session" \
-H "Content-Type: application/json" \
-d "{\"email\": \"hector@lootlocker.io\", \"password\": \"super_secret_password\"}"
The initial login request is simple in that it just requires the users email and password sent in a POST request.
The response can vary depending if the user has Two-Factor Authentication enabled or not. See examples for more detail.
If the user has Two-Factor Authentication enabled, the mfa_key
, sent back has en expiry time of 5 minutes. If the user does not manage to input the MFA token during this time, you should present them with the login form again.
Example response with Two-Factor Authentication enabled.
{
"success": true,
"mfa_key": "c1b7e16b5ea72c0b2ea2d383f6a329a4483bd763"
}
Example response without Two-Factor Authentication enabled.
{
"success": true,
"auth_token": "2068c2a0c56bca8d058a311f727d89f7233ccf24",
"user": {
"id": 12345,
"name": "Andreas Stokholm",
"email": "andreas@lootlocker.io",
"signed_up": 1606730113,
"organisations": [
{
"id": 2,
"name": "LootLocker",
"games": [
{
"id": 1,
"is_demo": false,
"name": "Rabbidt",
"badge_url": null,
"logo_url": null,
"development": {
"id": 2,
"is_demo": false,
"name": "Rabbidt",
"badge_url": null,
"logo_url": null
}
},
{
"id": 3,
"is_demo": false,
"name": "Kingfall",
"badge_url": null,
"logo_url": null,
"development": {
"id": 4,
"is_demo": false,
"name": "Kingfall",
"badge_url": null,
"logo_url": null
}
}
]
}
]
}
}
In case of an error, the response will have the success
property set to false
, and there will be an error
property with a human readable error message.
Two-Factor Authentication Code Verification
curl -X POST "https://api.lootlocker.io/admin/v1/2fa" \
-H "Content-Type: application/json"
-d "{\"mfa_key\": \"c1b7e16b5ea72c0b2ea2d383f6a329a4483bd763\", \"secret\": 123456}"
When the user has Two-Factor Authentication enabled, you need to request a code from the user, using the Google Authenticator standard.
To submit the code, you need to send the mfa_key
you got in the Initial Authentication Request, along with the secret
you got from the user.
This request requires a JSON request body, and thus it the Content-Type
header set to application/json
.
The successful response from this endpoint is the same as what you will get from the Initial Authentication Request, if Two-Factor Authentication is not enabled for the user.
In case the user is using a recovery token, you will not handle anything differently, but you can not limit the input to 6 characters since the recovery code is 27 characters long.
Example of a successful verification
{
"success": true,
"auth_token": "2068c2a0c56bca8d058a311f727d89f7233ccf24",
"user": {
"name": "Andreas Stokholm",
"email": "andreas@lootlocker.io",
"signed_up": 1606730113,
"organisations": [
{
"id": 2,
"name": "LootLocker",
"games": [
{
"id": 1,
"is_demo": false,
"name": "Rabbidt",
"badge_url": null,
"logo_url": null,
"development": {
"id": 2,
"is_demo": false,
"name": "Rabbidt",
"badge_url": null,
"logo_url": null
}
},
{
"id": 3,
"is_demo": false,
"name": "Kingfall",
"badge_url": null,
"logo_url": null,
"development": {
"id": 4,
"is_demo": false,
"name": "Kingfall",
"badge_url": null,
"logo_url": null
}
}
]
}
]
}
}
In case of an error, the response will have the success
property set to false
, and there will be an error
property with a human readable error message.
Subsequent requests
# Example of a subsequent call using header for auth token
curl -X GET "https://api.lootlocker.io/admin/v1/games" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Your subsequent requests should have a header property called x-auth-token
, with the auth_token
you got from either the Initial Authentication Request or the Two-Factor Authentication Code Verification request.
Games
Get All Games to the Current User
curl -X GET "https://api.lootlocker.io/admin/v1/games" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
To get all games, you have to send a request to /admin/games
. From here a JSON object will be returned containing simple information about a game.
Example response
{
"success": true,
"games": [
{
"id": 1,
"name": "SquirrelChaser",
"sandbox_mode": true,
"logo_url": null,
"badge_url": null,
"development": {
"id": 2,
"name": "SquirrelChaser",
"sandbox_mode": true,
"logo_url": null,
"badge_url": null
}
}
]
}
Creating A Game
curl -X POST "https://api.lootlocker.io/admin/v1/game" \
-H "x-auth-token: c72d54b4d7675de27e8e03e5e0015a4f1c456f1a" \
-H "Content-Type: application/json" \
-d "{\"name\": \"My Game\", \"organisation_id\": 1, \"genre\": 1}"
To create a game, you must send a POST request to /admin/game
with the game information.
The body of the request have to be in JSON format, and you must supply a Content-Type: application/json
header with the request.
Valid fields:
Field | Type | Info | Required |
---|---|---|---|
name | string | Max length: 100 | required |
organisation_id | integer | ID of the organisation to create the game under | required |
genre | integer | ID of the genre the game is | not required |
To get the genres, see the List Genres API call.
This call will return a full game object, as documented in Get detailed information about a game.
Get Detailed Information About a Game
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Using the /admin/game/{game_id}
endpoint, you can fetch additional information about a game, there will be one game object, holding all information relevant to the game requested. Currently this will hold the following:
Field | Type | Value |
---|---|---|
id | integer | Game id |
name | string | Game name |
game_key | string | The games API key |
sandbox_mode | boolean | If the game is in sandbox mode or not |
created_at | string | The date the game was created in ISO8601 format |
updated_at | string | The date the game was last updated in ISO8601 format |
Example Response
{
"success": true,
"game": {
"id": 1,
"name": "SNOW Test",
"game_key": "ka3ad899dc00258r42eb761f7654cc40f03cb271",
"sandbox_mode": true,
"created_at": "2015-01-26T14:01:51+0000",
"updated_at": "2015-01-26T14:01:51+0000"
}
}
Updating Information About a Game
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"name\": \"SNOW Test 2\"}"
Updating game information happens at the /admin/game/{game_id}
endpoint, with a PATCH request.
It is important to note that updating these values does not affect data at Steam, PSN or any other platforms.
Fields you are allowed to update are:
Field | Type | Info |
---|---|---|
name | string | Max length: 100 |
game_key | string | SHA1 hash, length: 40 |
sandbox_mode | boolean |
Any other fields sent will simply be ignored.
The body of the request have to be in JSON format, and you must supply a Content-Type: application/json
header with the request.
The response from this request will return a full game object as explained in Get detailed information about a game.
Deleting games
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Deleting a game is done by hitting the /admin/game/{game_id}
endpoint with a DELETE request. This is not completely permanent, but there is no API method for undoing this action.
Example Response
{
"success": true
}
List Genres
curl -X GET "https://api.lootlocker.io/admin/v1/genres" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
List the genres LootLocker knows about using this api call.
Example Response
{
"success": true,
"genres": [
{
"id": 1,
"name": "Other"
},
{
"id": 2,
"name": "Action / Adventure"
},
{
"id": 3,
"name": "Arcade"
}
]
}
API Keys
Here are the endpoints for managing API keys for the game and server APIs.
Get API Keys
curl -X GET "https://api.lootlocker.io/admin/game/100/api_keys"
Get list of API keys.
URL Structure
/admin/game/<game_id>/api_keys
Example Response
{
"api_keys": [
{
"id": "01GH960JB7A7ZS6ZN2CE9NVZGP",
"game_id": 1,
"api_key": "prod_7ea64274ada14674905bc3683208e618",
"api_type": "game",
"name": "Production API key",
"created_at": "2022-11-07T13:55:53Z",
"updated_at": "2022-11-07T13:55:53Z"
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
Create API key
curl -X POST "https://api.lootlocker.io/admin/game/100/api_keys" \
-H "Content-Type: application/json" \
-d "{\"name\": \"Production API key\", \"api_type\": \"game\"}"
Create a new API key.
URL Structure
/admin/game/<game_id>/api_keys
Example Response
{
"id": "01GH9643C4DWZPHN9YT8G8S06N",
"game_id": 1,
"api_key": "prod_7ea64274ada14674905bc3683208e618",
"api_type": "game",
"name": "Production API key",
"created_at": "2022-11-07T14:57:48.548656525+01:00",
"updated_at": "2022-11-07T14:57:48.548656525+01:00"
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
Available input fields
All fields are required.
Field | Description |
---|---|
name | Optional, name of your API key, used for making it easier to recognise |
api_type | Which API to create the key for, either game or server |
Delete API key
curl -X DELETE "https://api.lootlocker.io/admin/game/100/api_key/01GH9643C4DWZPHN9YT8G8S06Ns"
Deletes the API key. This action cannot be undone, and will cause any users of the API to no longer be able to make requests.
Will return 204 NO CONTENT on success.
URL Structure
/admin/game/<game_id>/api_keys/<key_id>
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
key_id | ID of the API key |
Players
Listing Players
curl -X GET "https://api.lootlocker.io/admin/game/{game_id}/player/list?count=10&after=1234" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint allows you to list your players, with the newest players first.
Use the count
parameter to set how many records you want returned per page.
Use the after
to put a cursor from the pagination
object in, and get the next or previous page.
You can filter players by their environment by including the query env
with a value of either live
or stage
.
Example Response
{
"pagination": {
"total": 7,
"next_cursor": 24,
"previous_cursor": null
},
"items": [
{
"player_id": 1,
"name": "YourBestFriend",
"public_uid": "R2JCN6CG",
"first_party_ids": [
{
"value": "0a014e44-ded7-4f91-9c8e-2e5053b9f6d1",
"platform": "guest"
}
],
"last_seen": "2022-09-26T14:11:00Z",
"first_seen": "2022-09-26T11:18:11Z",
"environment": "live"
}
]
}
Searching For Players
curl -X GET "https://api.lootlocker.io/admin/game/{game_id}/player/search?query=76561198023004363" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
To search for players, see the example, and add your query in the query
url parameter.
The query can be any unique identifier for the player. The search is performed on the identifier used to register a session, as well as Public UID's and the players set name.
This endpoint uses pagination. Each page returns 50 rows.
Example Response
{
"players": [
{
"player_id": 760746,
"name": "a player",
"public_uid": "",
"first_party_ids": [
{
"value": "a player",
"platform": "psn"
}
],
"last_seen": "2022-04-27T14:05:28Z",
"first_seen": "2016-10-22T07:29:03Z",
"environment": "live"
}
]
}
Getting Total Player Count
curl -X GET "https://api.lootlocker.io/admin/game/{game_id}/player/count" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will allow you to get the total number of players for a game. The response is a single integer in a JSON object.
If you wish to get the count for the stage version of a game, use the stage game's id instead of the live in the url.
Example Response
{
"count": 5
}
Get Player Information
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/player/7" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
To get detailed information for a player, see the example, using the players ID (obtainable from the Searching For Players endpoint).
Example Response
{
"success": true,
"players": [
{
"id": 24,
"steamId": "76561198103370330",
"psn_account_id": null,
"last_seen": "2016-06-10 01:34:37",
"creation_date": "2015-04-03 00:18:48",
"banned": false,
"public": true
}
]
}
Get Player Score
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/player/7/score" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
To get the players current score and level, see the example.
Example Response
{
"success": true,
"score": 60991,
"last_level_up": "2016-05-18 20:35:37"
}
Add Player Score
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/players/7/score" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"score\": 100}"
You can add XP to a players account using the example. This will add the XP and trigger all the same events as when the player is gaining XP through normal ways, meaning that rewards will be granted and they will level up.
Example Response
{
"success": true,
"score": 61091,
"last_level_up": "2016-05-18 20:35:37"
}
Reset Player Score
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}/players/7/score" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
You can reset a players XP and Level using this endpoint. Beware that this will not reset previous rewards from leveling up, and other XP events.
Example Response
{
"success": true,
"score": 0,
"last_level_up": "2016-05-18 20:35:37"
}
Get Player Steam Profile Info
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/steam/76561198023004363" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This is a proxy method for getting information on steam users.
Example Response
{
"success": true,
"player": {
"name": "MrQ",
"avatar": "https://steamcdn-a.akamaihd.net/steamcommunity/public/images/avatars/50/502b0dd96b2163bbe4dcd3714800a8694e2254ea_full.jpg",
"profile_url": "http://steamcommunity.com/id/stkhlm/"
}
}
Get Player Inventory
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/player/7/inventory" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will let you get the players inventory, along with a few other pieces of information, such as if an item is refundable or not.
Example Response
{
"success": true,
"inventory": [
{
"id": "944",
"player_id": "24",
"asset_id": "16",
"game_id": "2",
"asset_variation_id": "28",
"reserved": "0",
"source": null,
"updated_at": "2015-03-10 19:10:55",
"variation_name": "poppermost-founder",
"refundable": false
},
{
"id": "945",
"player_id": "24",
"asset_id": "47",
"game_id": "2",
"asset_variation_id": "98",
"reserved": "1",
"source": null,
"updated_at": "2015-03-10 19:10:55",
"variation_name": "poppermost-13-tophat-founder",
"refundable": true
}
]
}
Refund Player Purchase
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}/player/7/inventory/5713" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will issue a return of a an item to a player.
The return can only be done if the item is refundable (meaning it's been purchased with soft currency, through the Game API). When refunding, the players account balance will be refunded, and the asset will disappear from their inventory.
Example Response
{
"success": true,
"inventory": [
{
"id": "944",
"player_id": "24",
"asset_id": "16",
"game_id": "2",
"asset_variation_id": "28",
"reserved": "0",
"source": null,
"updated_at": "2015-03-10 19:10:55",
"variation_name": "poppermost-founder",
"refundable": false
}
]
}
Get Currencies To Player (Legacy)
This endpoint is part of the legacy economy system. If you are working with the new system please refer to List Balances.
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/player/7/currencies" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will return the currencies a player has and the balances they have for each currency.
Example Response
{
"success": true,
"currencies": [
{
"name": "Credits",
"balance": "15952"
}
]
}
Get Orders To Player
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/player/7/orders" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint returns a players orders and the products in them.
{
"success": true,
"orders": [
{
"id": "8077496",
"player_id": "7",
"game_id": "2",
"status": "2",
"created_at": "2016-06-26 12:28:52",
"updated_at": "2016-06-26 12:28:52",
"deleted_at": null,
"status_name": "succeeded",
"type": "asset_grant",
"value": "0",
"items": [
{
"id": "8777231",
"player_id": "7",
"asset_id": "988",
"game_id": "2",
"asset_variation_id": null,
"reserved": "0",
"source": "reward_trigger"
}
]
},
{
"id": "8077495",
"player_id": "7",
"game_id": "2",
"status": "2",
"created_at": "2016-06-26 07:28:37",
"updated_at": "2016-06-26 07:28:38",
"deleted_at": null,
"status_name": "succeeded",
"type": "asset_grant",
"value": "0",
"items": [
{
"id": "8777230",
"player_id": "7",
"asset_id": "984",
"game_id": "2",
"asset_variation_id": null,
"reserved": "0",
"source": "reward_trigger"
}
]
}
]
}
Set A Players Profile Private
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}/player/public" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Players profiles are by default public.
A public profile means that the players inventories will be displayed on steam, and they will be able to use the market and trading features. The same goes for future 3rd party implementations. They will all respect the privacy setting.
Example Response
{
"success": true
}
Set A Players Profile Public
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/player/public" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint sets a players profile to public.
Example Response
{
"success": true
}
Delete a Players Profile
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}/player/{player_id}" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint drops all references to the player, and effectively deletes the players account, in compliance with GDPR.
Example Response
{
"success": true
}
List Players Persistent Storage
curl -X GET "https://api.lootlocker.io/admin/v1/game/1234/player/5678/storage" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
If you want to list a players persistent player storage, this call will return it for you.
There are three properties on player persistent storage:
Example Response
{
"success": true,
"storage": [
{
"key": "totalDeaths",
"value": "171",
"is_public": false
}
]
}
Property | Data Type | Explanation |
---|---|---|
key | string | The key of the persistent storage entry |
value | string | The value of the persistent storage entry |
is_public | boolean | A boolean denoting if other players can read this persistent storage entry |
Update Players Persistent Storage
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/1234/player/5678/storage" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-d "{\"payload\":[{\"key\":\"totalDeaths\",\"value\":\"171\",\"is_public\":true}]}"
When updating a players persistent storage, the format is the same as the output when listing, inside the storage
property.
Note the payload
outer property. You can omit that if your use case does not require a JSON object at the root level.
Example Response
{
"success": true,
"storage": [
{
"key": "totalDeaths",
"value": "171",
"is_public": true
}
]
}
Delete Players Persistent Storage
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/1234/player/5678/storage?key=user.key" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Calling this endpoint will delete an entry associated with the supplied key from a players persistent storage.
Example Response
{
"success": true,
"storage": [
{
"key": "totalDeaths",
"value": "171",
"is_public": true
}
]
}
Lookup multiple player names using IDs
curl -G "https://api.lootlocker.io/admin/game/1234/player/lookup/name" \
-d player_id=1 \
-d player_id=2 \
-d player_public_uid=JARL7PGR \
-d player_guest_login_id=a270686a-7dd7-482f-89b6-9b2a634f46fb \
-d steam_id=9465748036854778475 \
-d psn_id=1234567890 \
-d xbox_id=E51D19530BBE721286F75C03B934E5EB7CA23B99 \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will return the names of the players on their last active platform.
Example Response
{
"players": [
{
"player_id": 1,
"player_public_uid": "6DDXH947",
"name": "Player 1 Name",
"last_active_platform": "xbox_one"
},
{
"player_id": 2,
"player_public_uid": "4FDGF738",
"name": "Player 2 Name",
"last_active_platform": "xbox_one"
},
{
"player_id": 3,
"player_public_uid": "JARL7PGR",
"name": "Player 3 Name",
"last_active_platform": "guest"
},
{
"player_id": 4,
"player_public_uid": "9HDK4F5Y",
"name": "Player 4 PSN Name",
"last_active_platform": "psn",
"platform_player_id": "1234567890"
},
{
"player_id": 5,
"player_public_uid": "3XTMHFS3",
"name": "Player 5 Steam Name",
"last_active_platform": "steam",
"platform_player_id": "9465748036854778475"
},
{
"player_id": 6,
"player_public_uid": "9RKPSRRT",
"name": "Player 6 XBox Name",
"last_active_platform": "xbox_one",
"platform_player_id": "E51D19530BBE721286F75C03B934E5EB7CA23B99"
},
{
"player_id": 7,
"player_public_uid": "T4HV7G5D",
"name": "Player 7 GuestLogin Name",
"last_active_platform": "guest",
"platform_player_id": "a270686a-7dd7-482f-89b6-9b2a634f46fb"
}
]
}
Player Files
Player Files is a feature where you can store files for players in LootLocker's storage system, where they will then be distributed through our CDN for fast retrieval by your players. This feature can be used for any files you wish to save to LootLocker in a players scope, such as Cloud Saves, Avatars or any other reason you can come up with.
Limitations
There are two limitations on Player Files:
- Each file can be a maximum of 5MB.
- There can be a maximum of 50 files per player.
List Files
curl -X GET 'https://api.lootlocker.io/admin/game/:game_id/player/:player_id/files' \
-H 'x-auth-token: 5995a0ce1afe87ac9dd49c509bd2fcae6f7d79ab' \
-H "LL-Version: 2021-03-01"
Use this endpoint for listing the files a player owns.
The url_expires_at
timestamp will let you know when you need to renew the URL for the download to work. URL's are valid for 6 hours.
Example Response
{
"items": [
{
"id": 318,
"revision_id": "01GPNZHCVEF6F0QGA3V2B7CN44",
"name": "smol.jpg",
"size": 7056,
"purpose": "SAVE_GAME",
"public": false,
"url": "https://cdn.lootlocker.io/2/892/oJnNPGsiuzytMOJPatwtPilfsfykSBGp.jpg?Expires=1635369933&Signature=Wp-PUZdoh3XdqQNOnPP80-q81ftGpLVJ3oub3RajnfjaP15rHzVWCCJ8e8lzpzrzdilu1gxoTiK1NT7iZayJXV~1XvcagCbkLCsrLkHlDZ0ms17C1YL5iNu1crBCJOhOhpwhknDmgt95NWa2GjLydylj7-0mqjALoURAMzpWvmbXUClUhtzIgGsBIEn2jy~syplWtMstTHE13EHmsxqfbAr8fkp91JGHaLFqSJL5YvlnIe5WoVNeBII8tjBb6YtEEF2dyliLyJOk8RaGtCDodKMmwOlwAlw-~lyfPrUOxH62c87-vkn8~uPQgAxcX0kp6NDudFrO5uiyESyOymIscw__&Key-Pair-Id=APKAIIBA3IODTCVA4BKQ",
"url_expires_at": "2021-10-27T21:25:33.339117882Z",
"created_at": "2021-10-27T14:20:31Z"
}
]
}
Update a File
curl -X PUT 'https://api.lootlocker.io/admin/game/:game_id/player/:player_id/files/:file_id' \
-H 'x-auth-token: 5995a0ce1afe87ac9dd49c509bd2fcae6f7d79ab' \
-H "LL-Version: 2021-03-01" \
-F 'file=@"path/to/your/file"'
Use this endpoint to update a player file, updating a player file will create a new revision of that file. The system will keep last few revisions so you can rollback to a previous one if desired.
Successful upload example response
{
"id": 318,
"revision_id": "01GPNZHCVEF6F0QGA3V2B7CN44",
"name": "save_game_1.zip",
"size": 7056,
"purpose": "SAVE_GAME_SLOT_1",
"public": false,
"url": "https://cdn.lootlocker.io/2/892/oJnNPGsiuzytMOJPatwtPilfsfykSBGp.jpg?Expires=1635366031&Signature=Z7MG~WgUyqpBNlXRePXxuV2uFbI0fEkAa3chk-3YO2XlWyd1veSl5V2dmFyVM1CndY6cfHo9ds3ilthwY~NjUiFmrx6ycfG3GJ5Z~kqzuyyMpH~LXTh~tIwnZpJpKScFUeBz5PpkSQPfOo4nuWktQBmpIgOhLlD2cWKOlQllBaIhjFvUh1HGIs-1u2-DiX9eDIgBDYzP4k0aMGH0aKjKF8Wb1jbAwaAcvQBeiPC~B~DgjlsHy6UjS59nYLCI-3EMheivk7H5-z-R65Au8VGg1koP89QtEjViy2HKbMKId~tQ3-cJg-ylRGHbE7jGlRyFC9CQLfeJXqx-IgaKfjVZCQ__&Key-Pair-Id=APKAIIBA3IODTCVA4BKQ",
"url_expires_at": "2021-10-27T20:20:31.433987069Z",
"created_at": "2021-10-27T14:20:31.428496822Z"
}
The url_expires_at
timestamp will let you know when you need to renew the URL for the download to work. URL's are valid for 6 hours after uploading, or using any endpoint that returns the files.
Exceeded file size example response
{
"message": "file too large",
"request_id": "req_6eb044d0-5b1e-45cc-8651-f72b3ee44985"
}
List File Revisions
curl -X GET 'https://api.lootlocker.io/admin/game/:game_id/player/:player_id/files/:file_id/revisions' \
-H 'x-auth-token: 5995a0ce1afe87ac9dd49c509bd2fcae6f7d79ab' \
-H "LL-Version: 2021-03-01"
This endpoint lists all revisions for the file, revisions are populated as the player file is updated.
Example Response
{
"file": {
"id": 6951,
"name": "smol.jpg",
"purpose": "SAVE_GAME",
"public": false,
"created_at": "2021-10-24T14:20:31Z"
},
"current_revision_id": "01GPNZHCQ3119Q6K4VRS16V3HB",
"revisions": [
{
"id": "01GPNZHCQ3119Q6K4VRS16V3HB",
"size": 7056,
"url": "https://cdn.lootlocker.io/10700/7604/bTyIgBowZuWeZDlhlpCwnbSgvOWmONmB.jpg?Expires=1673631081&Signature=UtS0H3XDdZc72aZhDF6~lB-~XOxYc7n9borwGrgZLrAFZ2Baqq5V0Iy-vsTKeS3JyLHmtBfDxE6ZmQdxCY0GRBL8R8iSvdvufftKr~6HWq~UXxKbNxg6hePXk-r8gJ5rL58zv5aSO8vrOZwfvKtdjmo-buOICrum~cq1MQembbfe9i0qP9drhX2xLkiCIxysVgVqCok8~DC9ymvOAKDK1vrKTIPmZBKre~sWsG1z3kOP0fH~jQpb6s8b7bnywIsky8MFOHJjJ-zpqyOZOXNNf2ysu1lDfslC13sbYO-FFjzFYUqjDPnnJAuHl5W9J0y7icrZ0n-AzEDHs6IBQqTlFQ__&Key-Pair-Id=APKAIIBA3IODTCVA4BKQ",
"created_at": "2021-10-27T14:20:31Z"
},
{
"id": "01GPNZHCVEF6F0QGA3V2B7CN44",
"size": 7056,
"url": "https://cdn.lootlocker.io/10700/7604/gTwDtqxVpEmetTuuryfVRDttqGjQSwQn.jpg?Expires=1673631081&Signature=hVF-3Ah~2KtlUq35k9oLd8SYsiMhIab3wGJ06euxj-PerwkJlOfb3RtFx1P2viV8zcqKVkJ2Wm2eIII23F9AzMjU12LENojke7Q5jiwuCjPFRoq-5bxE~mc4Dol9mdbUNstkfnO4faV9OUaKAlMuWAndbgZNrVca78kTZgA~TReq3Ov5a-4W5eWZO5THN4w78ZKo9OJY~MVu0hfjV3FAKoCFCPDl3GvDjarEdFgDkPWktTysYP4dfLv6W0C1JahOmhDSnSsVnQyf3WgKOLaIa1Cz~Dg-qd3m0uinZjsZh-MQXvcKHDfq9NpUlESjoPuXxLOyMz0d1NKJAewp3Ep0IQ__&Key-Pair-Id=APKAIIBA3IODTCVA4BKQ",
"created_at": "2021-10-27T14:20:31Z"
}
]
}
Tag Revision As Current
curl -X POST "https://api.lootlocker.io/admin/game/:game_id/player/:player_id/files/:file_id/revisions/:revision_id/current" \
-H 'x-auth-token: 5995a0ce1afe87ac9dd49c509bd2fcae6f7d79ab' \
-H "LL-Version: 2021-03-01"
This endpoint will tag the desired file revision as current, and that file revision will be served on all endpoints as the current one.
This endpoint will not have a body, being a 204 No Content
HTTP response.
Delete File
curl -X DELETE "https://api.lootlocker.io/admin/game/:game_id/player/:player_id/files/:file_id" \
-H 'x-auth-token: 5995a0ce1afe87ac9dd49c509bd2fcae6f7d79ab' \
-H "LL-Version: 2021-03-01"
If you need to delete a file, this endpoint will allow you to do that.
This endpoint requires a parameter in the URL, holding the ID of the file you wish to obtain. You will get the ID of files when you upload them, or call the list endpoint.
This endpoint will not have a body, being a 204 No Content
HTTP response.
The file will be deleted immediately and the action can not be reversed.
Player Progressions
Player progression API is used to track your player's progress on your game's progressions.
You can also add or subtract points, reset or delete player's progressions using this API.
Starting a player on a progression is as easy as just starting to add points to it.
Get Player Progressions
curl -X GET "https://api.lootlocker.io/admin/game/100/player/1/progressions?count=10&after=01GJN6J46DM00Z88WR225Y9P77"
Get list of progressions the specified player is currently on. Results are always sorted by ID.
URL Structure
/admin/game/<game_id>/player/<player_id>/progressions
Example Response
{
"pagination": {
"next_cursor": null,
"previous_cursor": null,
"total": 2
},
"items": [
{
"id": "01GJN6J46DM00Z88WR225Y9P77",
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_key": "fighter",
"progression_name": "fighter",
"step": 1,
"points": 200,
"previous_threshold": 0,
"next_threshold": null,
"last_level_up": null
},
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "mage",
"progression_name": "mage",
"step": 3,
"points": 1300,
"previous_threshold": 1000,
"next_threshold": 2000,
"last_level_up": "2022-11-24T16:12:41Z"
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
Query Parameters:
Field | Description |
---|---|
after | Cursor for pagination, a cursor will be returned in the response |
count | Number of progressions returned per page. Max 500 is allowed |
Get Player Progression By ID
curl -X GET "https://api.lootlocker.io/admin/game/100/player/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF"
Get a single player progression by ID.
URL Structure
/admin/game/<game_id>/player/<player_id>/progressions/<progression_id>
Example Response
{
"id": "01GJN6J46DM00Z88WR225Y9P77",
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_key": "fighter",
"progression_name": "fighter",
"step": 1,
"points": 200,
"previous_threshold": 0,
"next_threshold": null,
"last_level_up": null
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
progression_id | ID of the progression |
Add points to a player progression
curl -X POST "https://api.lootlocker.io/admin/game/100/player/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF/points/add" \
-d "{\"amount\": 1000 }" \
-H "Content-Type: application/json"
Adds specified amount of points to a player progression. If the player is not on that progression it will be automatically started.
If the player leveled up, awarded_tiers fields will contain acquired rewards.
URL Structure
/admin/game/<game_id>/player/<player_id>/progressions/<progression_id>/points/add
Example Response
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "mage",
"progression_name": "mage",
"step": 3,
"points": 1300,
"previous_threshold": 1000,
"next_threshold": 2000,
"last_level_up": "2022-11-24T16:12:41Z",
"awarded_tiers": [
{
"id": "01GJ34GY6XD0NGRHXV6HHVJYM9",
"step": 2,
"points_threshold": 400,
"rewards": {
"progression_points_rewards": [
{
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_name": "fighter",
"progression_key": "fighter",
"amount": 100
}
],
"progression_reset_rewards": [
{
"progression_id": "01GJ34K7QBEB124MVE8BCFPAMG",
"progression_name": "rogue",
"progression_key": "rogue"
}
],
"asset_rewards": [
{
"asset_id": 2,
"asset_variation_id": null,
"asset_rental_option_id": null
}
],
"currency_rewards": [
{
"currency_id": "01HEJHRJ85PB157YV2GMHP79W1",
"currency_name": "Gold",
"currency_code": "GLD",
"amount": "100"
}
]
}
},
{
"id": "01GJ34H31MKHQD09K12WFEEQ4A",
"step": 3,
"points_threshold": 1000,
"rewards": {
"progression_points_rewards": [],
"progression_reset_rewards": [],
"asset_rewards": [],
"currency_rewards": []
}
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
progression_id | ID of the progression |
Available input fields
amount is required.
Field | Description |
---|---|
amount | Amount of points to be added to the player's progression. |
Subtract points from a player progression
curl -X POST "https://api.lootlocker.io/admin/game/100/player/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF/points/subtract" \
-d "{\"amount\": 10 }" \
-H "Content-Type: application/json"
Subtracts specified amount of points from a player progression. The player cannot go down a progression step, the points will be set to the previous_threshold if too many points are being subtracted.
URL Structure
/admin/game/<game_id>/player/<player_id>/progressions/<progression_id>/points/subtract
Example Response
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "mage",
"progression_name": "mage",
"step": 3,
"points": 1290,
"previous_threshold": 1000,
"next_threshold": 2000,
"last_level_up": "2022-11-24T16:12:41Z",
"awarded_tiers": []
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
progression_id | ID of the progression |
Available input fields
amount is required.
Field | Description |
---|---|
amount | Amount of points to be subtracted from the player's progression. |
Reset a player progression
curl -X POST "https://api.lootlocker.io/admin/game/100/player/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF/reset" \
-H "Content-Type: application/json"
Resets a player progression. This endpoint sets the player progression points to 0, so it still shows up as an active progression.
URL Structure
/admin/game/<game_id>/player/<player_id>/progressions/<progression_id>
Example Response
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "mage",
"progression_name": "mage",
"step": 1,
"points": 0,
"previous_threshold": 0,
"next_threshold": 1000,
"last_level_up": null,
"awarded_tiers": []
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
progression_id | ID of the progression |
Delete a player progression
curl -X DELETE "https://api.lootlocker.io/admin/game/100/player/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF" \
-H "Content-Type: application/json"
Deletes a player progression. It won't show up in player's active progression list.
URL Structure
/admin/game/<game_id>/player/<player_id>/progressions/<progression_id>
Example Response
This endpoint will not have a body, being a
204 No Content
HTTP response.
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
progression_id | ID of the progression |
Assets
Getting all assets to a game
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/assets" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
To get all assets to a game, call /admin/game/{game_id}/assets
and you will get an array back with simple information about a games assets.
This call can be sped up by utilizing pagination for large datasets. By adding a page
parameter to the end of the url, you will be requesting chunks of 100 assets per page. When you get an empty response, you've fetched all assets.
Example Response
{
"success": true,
"assets": [
{
"id": 1,
"uuid": "8b860287-5d50-4948-8661-75dbe87b6506",
"active": true,
"purchasable": false,
"tradable": false,
"marketable": false,
"name": "Head",
"context": "Head",
"last_changed": "2016-08-07T05:08:01+0000",
"price": 0,
"sales_price": 0,
"filters": [],
"thumbnail": "attachments/head...",
"variations": [
{
"id": "1",
"asset_id": "1",
"name": "Default",
"primary_color": null,
"secondary_color": null,
"created_at": "2015-02-20 21:53:34",
"updated_at": "2015-02-20 21:53:34",
"deleted_at": null
}
],
"rental_options": null,
"storage": null,
"flagged": null
},
{
"id": 3,
"uuid": "79838f0f-cc37-4854-a81f-eedf7be469b8",
"active": true,
"purchasable": true,
"tradable": false,
"marketable": false,
"name": "Credits",
"context": "Credits",
"last_changed": "2016-08-07T05:08:01+0000",
"price": 1000,
"sales_price": 0,
"filters": [
{
"name": "filter-test",
"value": "great success"
}
],
"thumbnail": "https://cdn.lootlocker.io/...",
"variations": [],
"rental_options": null,
"storage": null,
"flagged": null
}
]
}
You can filter the response to only contain certain contexts by supplying a GET parameter in the URL named context_id
, containing the ID of the context you wish returned.
You can also search for assets using this endpoint. The search term will match asset names and context names. The parameter for searching is a GET
style url parameter named search
. Eg: https://api.lootlocker.io/admin/v1/game/{game_id}/assets?search=rocket
.
You can optionally include the following list of flags in the fields
parameter to return other fields in this result too. The fields parameter is a comma separated list of the flag
values from the below table, in a get style parameter named fields
. Eg: https://api.lootlocker.io/admin/v1/game/{game_id}/assets?fields=unique,context_id
.
Flag | Field | Type | Value |
---|---|---|---|
unique | is_unique_instance | boolean | A boolean if an asset is marked as unique instance or not |
rarity | rarity_id | integer | An integer containing the id of the rarity of the asset |
context_id | context_id | integer | An integer with the ID of the context the asset belongs to |
global | is_global | boolean | A boolean denoting if the asset is currently global/universal or not |
global_schedule | global_schedule | array of objects | An array of all scheduled global/universal times for this asset. See Global Assets for data structure. |
Getting a list of assets to a game
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/assets/1,2,3,4,916" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This call will return the same response format as getting all assets to a game will, but only data for the specific assets id's you've supplied in the url.
Get detailed asset information
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/asset/1" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This call will return a lot of information about an asset, and should only be used when listing detailed asset information.
Example Response
{
"success": true,
"asset": {
"id": 5,
"uuid": "4785e978-09f9-4e07-83bd-ed36600930d4",
"active": true,
"purchasable": true,
"name": "Sven",
"last_changed": "2016-08-07T05:08:01+0000",
"price": 39,
"sales_price": 0,
"on_steam": true,
"languages": {
"1": {
"id": 1,
"name": "US English"
}
},
"context_id": 4,
"global": null,
"featured": null,
"activation_errors": [],
"min_game_version_id": 0,
"rarity": null,
"popular": false,
"popularity_score": 0,
"unique_instance": false,
"external_identifiers": null,
"contexts": [
{
"id": 1,
"name": "Head"
},
{
"id": 2,
"name": "Flashlight"
},
{
"id": 58,
"name": "Feature Unlocks"
}
],
"background_color": "",
"name_color": "089AEF",
"tradable": false,
"marketable": false,
"market_name": "Test 1",
"market_hash_name": "Test 1",
"market_fee": "0.30",
"links": [],
"link_types": {
"1": {
"id": 1,
"name": "Steam Square",
"type": 0
},
"2": {
"id": 2,
"name": "Steam Big",
"type": 0
},
"3": {
"id": 3,
"name": "In-game Thumbnail",
"type": 1
},
"8": {
"id": 8,
"name": "In-game Square",
"type": 1
}
},
"game_versions": [
{
"id": 2,
"version": "0.5.1.569095"
},
{
"id": 3,
"version": "0.5.2.571294"
}
],
"is_package": false,
"variations": [
{
"id": 3,
"name": "lo2-gloves-13-sven",
"default": true,
"primary_color": "818987",
"secondary_color": "EE8D29",
"links": [
{
"id": 1,
"url": "CharacterAttachments/Item Thumbnails/hands/lo2/thumb_lo2-13-sven.tif",
"type_id": 3
},
{
"id": 449,
"url": "https://pm-game-files.s3.amazonaws.com/2/54eefc7c704bc.png",
"type_id": 1
},
{
"id": 456,
"url": "https://pm-game-files.s3.amazonaws.com/2/54eefc7fe4111.png",
"type_id": 2
}
],
"properties": [
{
"material_path": "CharacterAttachments/hands/lo2/lo2-gloves-13-sven/lo2-gloves-13-sven.mtl",
"binding_path": "CharacterAttachments/hands/shared-meshes/gloves-a/gloves-a.skin",
"bone_id": 12,
"min_game_version_id": null
},
{
"material_path": "CharacterAttachments/hands/lo2/lo2-gloves-13-sven/lo2-gloves-13-sven.mtl",
"binding_path": "characterattachments/hands/shared-meshes/gloves-a/gloves_a_geo.skin",
"bone_id": 12,
"min_game_version_id": 20
}
]
}
],
"filters": {
"1": {
"name": "Brand",
"id": "1",
"value": {
"value": "lo2",
"url": null
}
},
"2": {
"name": "Season",
"id": "2",
"value": {
"value": "13/14",
"url": null
}
},
"5": {
"name": "Drop Point Category",
"id": "5",
"value": null
}
},
"bones": [
{
"id": 12,
"name": "arms"
},
{
"id": 7,
"name": "bindings_left"
},
{
"id": 8,
"name": "bindings_right"
}
],
"boneParameters": [
{
"name": "type",
"value": "CA_SKIN",
"bone_id": "12"
},
{
"name": "rotation",
"value": "1,0,0,0",
"bone_id": "7"
},
{
"name": "position",
"value": "-0.16281861,0.007631816,-0.93363667",
"bone_id": "7"
},
{
"name": "boneName",
"value": "Bip01 L Foot",
"bone_id": "7"
},
{
"name": "flags",
"value": "0",
"bone_id": "7"
},
{
"name": "type",
"value": "CA_BONE",
"bone_id": "7"
}
],
"package_contents": [],
"drop_table_groups": [],
"drop_table_max_picks": null,
"drop_table_roll_count": null,
"simple_asset": false
}
}
For a table structure of a full response, please see the Asset Data Structures section of this documentation.
Create asset
# Creating an asset, setting only some information
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/asset" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
-H "Content-Type: application/json"
-d "{\"context_id\": 1, \"name\": \"Energy Drink Deluxe\", \"actions\": [{\"url\": \"http://www.snowthegame.com\", \"name\": \"Game website\", \"owner_only\": false}]}"
There are only a few required fields, but you can only activate an asset when it's complete.
Required fields: context_id
and name
.
The response from this call will be equal to a response from Get Detailed Asset Information.
For a full list of properties that can be set when creating an asset, please refer to the Asset Data Structures.
Update asset
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/asset/4" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
When you wish to update an asset, use this endpoint. It takes the same input as the Create Asset endpoint, and returns the same response.
For a full list of properties that can be set when updating an asset, please refer to the Asset Data Structures.
Delete asset
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}/asset/4" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint allows you to delete an asset, removing it from the admin interface. The asset will need to be deactivated before deletion.
The endpoint can only be used to delete stage assets. Once deletion is complete, you can merge the change to the live environment via the Management Console.
Checking If An Asset Can Be Activated
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/asset/4/can/activate" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This call will return a boolean called can_activate
telling you if an asset can be activated or not. If it can not, you will also see an errors
property, which will be an array containing the reasons an asset can not be activated. In the example response you see an error. In case of a success, the error
property will not be present, and the can_activate
will hold the value true
.
Example Error Response
{
"success": false,
"can_activate": false,
"errors": ["No context have been assigned to this asset."]
}
Example Success Response
{
"success": true,
"can_activate": true
}
Activating An Asset
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/asset/4/activate" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Issuing this call will activate the asset id you've provided.
In case of an error, you will get a response identical to what Checking If An Asset Can Be Activated returns. In case of a success, you will simply have a success
property with the value true
.
Example Response
{
"success": true
}
Deactivating An Asset
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/asset/4/deactivate" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-d "{\"reason\": \"Here is a good reason for deactivating this asset\", \"replacement_asset_id\": 5}"
This is what an example deactivation call could be, it takes a JSON input, with one or two properties: reason
and replacement_asset_id
. You can supply both, and you must supply at least one of them. The reason will be displayed to players as a notification when they boot the game, and the replacement_asset_id will be silent.
In case you get any errors back from this call, there will be an error
property in the payload which will hold an array of text errors. See example.
Example Error Response
{
"success": false,
"error": [
"When not supplying a replacement asset, you must give a reason for deactivating the asset.",
"When not supplying a reason for deactivating an asset, you must supply a replacement asset."
]
}
When you get successful response, you will simply see a success
property with the value true
.
Get Contexts
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/assets/contexts" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
To list the contexts configured for the current game, call this endpoint.
Example Response
{
"success": true,
"contexts": [
{
"id": 1,
"uuid": "20914798-d428-4a11-99a1-64ebac1c8d60",
"name": "Head",
"friendly_name": null,
"detachable": false,
"user_facing": false,
"characters": {
"skier": true,
"snowboarder": true
},
"dependent_asset_id": false,
"editable": true
},
{
"id": 6,
"uuid": "8b860287-5d50-4948-8661-75dbe87b6506",
"name": "Goggles",
"friendly_name": "Eyes",
"detachable": true,
"user_facing": true,
"characters": {
"skier": true,
"snowboarder": true
},
"dependent_asset_id": false,
"editable": true
}
],
"unlock_assets": [
{
"id": 1405,
"name": "Snowmobile Unlock"
}
]
}
The field friendly_name
is what will be showed in integrations and other external places.
detachable
denotes if this context can be unequipped without equipping a new asset in it's place. Eg; Goggles can be unequipped, pants can not.
The user_facing
field is a boolean indicating whether the context should be shown in integrations, such as Steam.
The characters
field is an array of character type names, if the value is true, the character type can interact with this context.
dependent_asset_id
denotes if this context is unlocked by the player owning a specific asset.
The editable
boolean is there to let you know if this is an editable context or not. A few default contexts will have this set to false. Any context you create will always be editable.
The unlock_assets
at the end of the data is the assets which qualify for being passed in to dependent_asset_id
. In simpler terms, it's assets which context is Feature Unlocks
.
Update Contexts
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/assets/contexts" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "[{\"name\": \"New Context\"}, {\"id\": 1, \"name\": \"Existing Context\"}]"
Updating contexts is done by updating them all at the same time. This is suboptimal, and is scheduled to be fixed in the future.
For the time being, you simply send the same format in as you get from the list, and change the values you want updated. If you want to create a new context, simply skip sending the id
field along, and it will be created as a new context. Contexts can not currently be deleted.
The response from this endpoint is the same as is returned from the Get Contexts call.
Grant Asset To Player
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/player/{player_id}/inventory/grant" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"asset_id\": 1, \"asset_variation_id\": 2}"
To grant an asset to a player through the admin API, you can use this endpoint. The asset_id
is required, and the asset_variation_id
and asset_rental_option_id
fields are optional.
If your asset has variations, not providing an asset_variation_id
will grant the default variation.
If your asset is a rental asset, the asset_rental_option_id
is required. Failing to provide it will cause an error.
If you do not want the granting of the asset to notify the player, you can add a silent
boolean to the request body. This will prevent the player from receiving a notification about the granted asset.
Example Response
{
"success": true,
"assets": [] // array of granted assets
}
Asset Data Structures
This section holds tables that describe data structures surrounding assets.
Asset Root Object
The asset root object is a representation of the Asset Object. Single value root level properties will be described here, while any sub structure will have it's own table.
There are only two required fields for creating an asset, everything else is optional, but might need to be set for the asset to be activated (sent to your game). The required fields are context_id
and name
.
JSON Object with all arrays and objects set to their empty states
{
"id": 2,
"uuid": "64ba8834-e95c-46be-9de7-3acbef07001b",
"live_asset_id": 1,
"dev_asset_id": null,
"active": true,
"purchasable": false,
"name": "Asset Name",
"last_changed": "2021-01-21T12:41:48+00:00",
"price": 0,
"sales_price": 0,
"on_steam": false,
"languages": [],
"context_id": 4,
"global": null,
"featured": null,
"activation_errors": [],
"min_game_version_id": 0,
"rarity": null,
"popular": false,
"popularity_score": 0,
"unique_instance": false,
"external_identifiers": {
"psn": null,
"apple_app_store": null,
"google_play": null
},
"rental_options": null,
"loot_box_content": null,
"drop_table_groups": null,
"drop_table_max_picks": null,
"drop_table_roll_count": null,
"filters": [],
"links": [],
"is_package": false,
"is_loot_box": false,
"is_rental": false,
"is_drop_table": false,
"bones": [],
"package_contents": [],
"simple_asset": false,
"flagged": null
}
Field | Type | Value |
---|---|---|
id | integer | The ID of the Asset |
uuid | string | This is a UUID v4 assigned to the Asset automatically by LootLocker. It is consistent across live and stage versions of your Asset. |
live_asset_id | integer | The ID of the live Asset if the current Asset is a dev version |
dev_asset_id | integer | The ID of the dev Asset if the current Asset is a live version |
name | string | The Asset name |
last_changed | string | The date when this Asset was last changed |
price | integer | The price of the Asset in cents or virtual currency |
sales_price | integger | Sets the Asset on sale, overriding the price in any transactions if bigger than 0 or null |
purchasable | boolean | Can this Asset be purchased? |
context_id | integer | The ID of the Context this Asset belongs to |
unique_instance | boolean | Can players own multiple or only one of this Asset? |
on_steam | boolean | A boolean referencing if this Asset is exposed to Steam |
background_color | string | HEX color. Used in Steam inventory. |
name_color | string | HEX color. Used in Steam inventory. |
tradable | boolean | Tradable on steam |
marketable | boolean | Marketable on steam |
market_name | string | Asset name in steam market |
market_hash_name | string | Asset name used for grouping in steam market |
market_fee | double | Percent from 0 to 1 to charge for steam market trades |
featured | object or null | Dates for featured, or null if not featured. |
global | object or null | Dates for global, or null if not global. See global Assets |
storage | object | An array of objects with two properties: key (string) and value (string). |
storage_templates | array of objects | An array of objects with Asset Storage Templates. See storage templates |
min_game_version_id | integer | The id of the lowest version of the game that supports this Asset. |
popular | boolean | Is this Asset popular? |
popularity_score | integer | A score of how popular this Asset is |
flagged | boolean or null | Applies only to UGC assets, and is null for all other Assets |
simple_asset | boolean | If this Asset's complexity is considered simple by LootLocker (No variations or special logic) |
drop_table_max_picks | int or null | An integer denoting how many dropped items the player is allowed to pick from a drop table. 0 and null = no limit |
drop_table_roll_count | int or null | An integer denoting how many times the configured drop table groups should be evaluated for drops. Default 1 . |
activation_errors | array | An array of strings holding human readable errors that need to be corrected before the Asset can be activated. |
external_identifiers | array | See asset external identifiers |
drop_table_groups | array | See asset drop table groups |
loot_box_content | array | See asset loot box content |
variations | array | See asset variations |
rarity | object | See asset rarities |
links | array | See asset images |
descriptions | array | See asset descriptions |
tags | array | See asset tags |
actions | array | See asset actions |
is_package | boolean | A boolean representing if this Asset is a package of Assets |
is_loot_box | boolean | A boolean representing if this Asset is a loot box |
is_rental | boolean | A boolean representing if this Asset is a rental Asset |
is_drop_table | boolean | A boolean representing if this Asset is a drop table |
package_contents | array | See asset package contents |
rental_options | array | See asset rental options |
Global Assets
Global assets can either be null
or be an object with a start and end date of the Assets global status. Note that the end date can also be null
if there is no end set for the global status.
JSON Object
{
"start_date": "2021-02-05 23:00:00",
"end_date": null
}
Field | Type | Value |
---|---|---|
start_date | string | The UTC time zone date and time from when the Asset is global |
end_date | string or null | The UTC time zone date and time from when the Asset is no longer global. Can also be null. |
Storage Templates
Storage Templates are used to add many key/value storage entries to multiple Assets easily. Multiple templates can be applied to the same Asset, where the order
is used to apply the templates from least significant to most significant. The key/value pairs set directly on the Asset override anything set in a template.
JSON Object
{
"storage_templates": [
{
"id": 1,
"order": 1
}
]
}
If you wish to remove one or more templates from an Asset, send the storage_template
property with only the template entries you wish to keep. LootLocker will automatically delete any entries that have not been sent along in the call.
Field | Type | Value |
---|---|---|
id | integer | The ID of the asset storage template |
order | integer | The order the templates are applied in when returned through the Game and Server APIs |
Asset External Identifiers
External Identifiers is how we map Assets to external services such as PSN, Apple's App Store and Google Play.
JSON Object
{
"external_identifiers": {
"psn": {
"entitlement_id": "entitlement id",
"product_id": "product id"
},
"apple_app_store": {
"product_id": "product id"
},
"google_play": {
"product_id": "product id"
}
}
}
Field | Type | Value |
---|---|---|
psn | object | An object holding the data necessary to map an asset to PSN |
psn.entitlement_id | string | The entitlement ID set up on PSN |
psn.product_id | string | The product ID set up on PSN |
apple_app_store | object | An object holding the data necessary to map an asset to Apple's App Store |
apple_app_store.product_id | string | The product ID set up on the App Store |
google_play | object | An object holding the data necessary to map an asset to Google Play |
google_play.product_id | string | The product ID set up on Google Play |
Asset Drop Table Groups
Asset Drop Table Groups allows the configuration of drop tables in LootLocker.
JSON Object
{
"id": 374,
"name": "My Group Name",
"weight": [70],
"tags": ["skeleton", "mage"],
"force_select": [false],
"min_drop_count": 1,
"max_drop_count": 4,
"grants": [],
"prevent_duplicate_drops": false
}
Field | Type | Value |
---|---|---|
id | int | The id of the drop table group |
name | string | A free form name you can give to your group for identification purposes. It's never exposed outside of the Admin API. |
weight | array of int | The weight representation of the group, starting from roll 1 going upwards |
tags | string array | Any tags associated with the group |
force_select | array of boolean | A boolean to force this group to drop loot (if not excluded by tags), starting from roll 1 going upwards |
min_grant_count | int | A minimum number of drops from this group |
max_grant_count | int | A maximum number of drops from this group |
grants | array | See asset drop table group grants |
prevent_duplicate_drops | boolean | Toggles prevention of duplicate drops from the same group if the same group is chosen in multiple rolls of the drop table. |
Tags in both Drop Table Groups and Drop Table Group Grants can be used to influence the selection of which assets get granted to the player. For example, if you play a specific level as a specific character (skeleton), you might want to make sure you only drop loot that the character can use, so tagging any items with skeleton
would allow you to only select those to be considered for granting. This applies to both groups and grants.
Asset Drop Table Group Grants
Asset Drop Table Group Grants is the grants that a drop table will select from when triggered.
JSON Object
{
"drop_table_group_id": 1,
"weight": 2,
"force_select": false,
"asset_id": 3,
"asset_variation_id": 4,
"asset_rental_option_id": null,
"tags": ["skeleton"],
"child_asset": {
"name": "Skeleton Sword",
"thumbnail": "https://cdn.lootlocker.io/...",
"variation_name": "Excaliburs Underwear",
"rental_option_name": null,
"price": 5,
"context": "Swords"
}
}
Field | Type | Value |
---|---|---|
drop_table_group_id | integer | The id of the Asset Drop Table Group this grant belongs to |
weight | integer | The weight representation of the grant |
force_select | boolean | A boolean to force this grant to drop (if not excluded by tags) |
asset_id | integer | The ID of the contained Asset |
asset_variation_id | integer | The id of the variation of the contained Asset or null |
asset_rental_option_id | integer | The id of the rental option of the contained Asset or null |
tags | string array | Any tags associated with the grant |
child_asset | object | An object with data to help represent the contained Asset |
child_asset.name | string | The name of the contained Asset |
child_asset.thumbnail | string | A url to a thumbnail for the contained Asset (Relative to the variation if present) |
child_asset.variation_name | string | The potential name of the variation of the contained Asset |
child_asset.rental_option_name | string | The potential name of the rental option of the contained Asset |
child_asset.price | integer | The price of the contained Asset |
child_asset.context | string | The name of the context the contained Asset belongs to |
Asset Loot Box Content
Asset Loot Box Content is an array of assets contained inside a Loot Box asset, represented in a simplified structure, which provides what is necessary to render a preview.
JSON Object
{
"asset_id": 1,
"asset_variation_id": null,
"asset_rental_option_id": null,
"weight": 1,
"group": 1,
"child_asset": {
"name": "Rail Gun",
"thumbnail": "url or path",
"variation_name": "Destroyer of Ships",
"rental_option_name": null,
"price": 100,
"context": "guns"
}
}
Field | Type | Value |
---|---|---|
asset_id | integer | The ID of the contained Asset |
asset_variation_id | integer | The id of the variation of the contained Asset or null |
asset_rental_option_id | integer | The id of the rental option of the contained Asset or null |
weight | integer | The weight representation of the grant |
group | integer | The group this grant belongs to |
child_asset | object | An object with data to help represent the contained Asset |
child_asset.name | string | The name of the contained Asset |
child_asset.thumbnail | string | A url to a thumbnail for the contained Asset (Relative to the variation if present) |
child_asset.variation_name | string | The name of the variation of the contained Asset |
child_asset.rental_option_name | string | The name of the rental option of the contained Asset |
child_asset.price | integer | The price of the contained Asset |
child_asset.context | string | The name of the context the contained Asset belongs to |
Asset Variations
Variations are used to allow sharing of properties between Assets that are very similar, such as hats that only vary in color or pattern, but otherwise are identical.
JSON Object with arrays set to default empty state
{
"id": 374,
"name": "Default",
"default": true,
"primary_color": null,
"secondary_color": null,
"links": [],
"properties": []
}
Field | Type | Value |
---|---|---|
id | integer | Variation ID |
name | string | The name of the variation |
default | boolean | If this is the assets default variation. This is used to select the variation if it is not provided specifically in other calls |
links | array | See asset images |
properties | array | See asset variation properties |
Asset Variation Properties
The properties of a variation can be used to let your game client know where to find the material and binding, which attachment (bone_id
) it belongs to and to set a minimum game version this variation should be returned to.
JSON Object
{
"material_path": "file path",
"binding_path": "file_path",
"bone_id": 79,
"min_game_version_id": null
}
Field | Type | Value |
---|---|---|
material_path | string | A path to a material stored in your game |
binding_path | string | A path to a binding stored in your game |
bone_id | integer | The id of the bone (Attachment) this variation belongs to |
min_game_version_id | integer | The id of the minimum game version this variation should be returned to |
Asset Descriptions
Descriptions show up in steam and other relevant places. Colors are used exclusively in steam for now.
JSON Object with arrays set to default empty state
{
"id": 1,
"active": true,
"owner_only": false,
"type": "text",
"color": "336699",
"label": "Gun: ",
"values": []
}
Field | Type | Value |
---|---|---|
id | integer | ID of description |
active | boolean | Is this description active? |
owner_only | boolean | Switch for showing publicly or only for owner |
type | enum | Possible values: text, html, image |
color | string | HEX color to display text type in |
label | string | Prefix before value |
values | array | See asset description values |
Asset Description Values
JSON Object
{
"id": 1,
"language_id": 1,
"value": "High speed rail gun"
}
Field | Type | Value |
---|---|---|
id | integer | ID of the value |
language_id | integer | ID of the language |
value | string | The actual value (Max length: 500) |
Asset Tags
Tags are used as filtering options in steam.
JSON Object with arrays set to default empty state
{
"id": 1,
"internal_name": "Gun tags",
"internal_category": "guns",
"tag_names": [],
"category_names": []
}
Field | Type | Value |
---|---|---|
id | integer | ID of the tag |
internal_name | string | Identifier for tag. Not user facing. |
tag_names | array | See asset tag names below |
internal_category | string | A category used by steam to group tags. Not user facing. |
category_names | array | See asset category names |
Asset Tag names
These are the translated variants of the tag. These are shown to the user.
JSON Object
{
"id": 1,
"language_id": 1,
"value": "localized tag name"
}
Field | Type | Value |
---|---|---|
id | integer | ID of the tag name |
language_id | integer | ID of the language |
value | string | Translated string (Max length: 100) |
Asset Category names
These are the translated variants of the category. They are shown to the user.
JSON Object
{
"id": 1,
"language_id": 1,
"value": "localized category name"
}
Field | Type | Value |
---|---|---|
id | integer | ID of the category name |
language_id | integer | ID of the language |
value | string | Translated string (Max length: 100) |
Asset Actions
Actions is a steam concept, and shows up as buttons in the steam inventory.
Steam helps with these and replaces the urls %assetid%
, %contextid%
, and %appid%
, with the asset's ID, context ID, and owning app ID, respectively.
JSON Object
{
"id": 1,
"url": "https://yourwebsite.com/assets/%assetid%",
"name": "See Asset",
"owner_only": true
}
Field | Type | Value |
---|---|---|
id | integer | Action ID |
url | string | URL endpoint for action |
name | string | The name of the action |
owner_only | boolean | Only show action for owner |
Asset Images
For legacy reasons images are referenced as links
in LootLocker at the moment.
Asset links can be present both on the root of an Asset, and on Asset Variations.
JSON Object
{
"id": 1,
"url": "url or file path",
"type_id": 1
}
Field | Type | Value |
---|---|---|
id | integer | Link ID |
url | string | A CDN url or in-game file path to the linked file |
type_id | integer | A reference to the type of link this is. |
Asset Rarities
Asset Rarities is an object holding information about the rarity of an asset. The object has 3 properties, which are all optional.
JSON Object
{
"id": 1,
"name": "Ultra Rare",
"short_name": "UR",
"color": "c6c891"
}
Field | Type | Value |
---|---|---|
id | integer | The ID of the rarity |
name | string | A name of the rarity, eg: Legendary |
short_name | string | A short version of the name, eg: L |
color | string | A HEX color for the rarity, eg: c6c891 |
Asset Package Contents
Package Content is an array of assets contained inside another asset, represented in a simplified structure, which provides what is necessary to render a preview. Packages can not contain other packages, so there will never be a nesting level deeper or a circular reference.
JSON Object
{
"asset_id": 1,
"asset_variation_id": 2,
"quantity": 1337,
"child_asset": {
"name": "Rail Gun",
"thumbnail": "url or path",
"variation_name": "Destroyer of Ships",
"price": 100,
"context": "guns"
}
}
Field | Type | Value |
---|---|---|
asset_id | integer | The ID of the contained Asset |
asset_variation_id | integer | The id of the variation of the contained Asset or null |
quantity | integer | The quantity of the contained asset |
child_asset | object | An object with data to help represent the contained Asset |
child_asset.name | string | The name of the contained Asset |
child_asset.thumbnail | string | A url to a thumbnail for the contained Asset (Relative to the variation if present) |
child_asset.variation_name | string | The name of the variation of the contained Asset |
child_asset.price | integer | The price of the contained Asset |
child_asset.context | string | The name of the context the contained Asset belongs to |
Asset Rental Options
Rental Options is the different pricing tiers and rental durations associated with a rental asset. They are represented in an array of objects.
JSON Object
{
"rental_options": [
{
"id": 1,
"name": "1 Day",
"duration": 86400,
"price": 500,
"sales_price": null,
"links": [
{
"id": 2,
"url": "https://cdn.lootlocker.io/...",
"type_id": 3
}
]
}
]
}
Field | Type | Value |
---|---|---|
id | integer | The ID of the Rental Option |
name | string | The name of the Rental Option |
duration | integer | The duration of the Rental Option, in seconds |
price | integer | The price of the Rental Option |
sales_price | integer | The sales_price of the Rental Option |
links | array of objects | Any images associated with the Rental Option |
links.id | integer | The ID of the link |
links.url | string | The URL/Path to the link (can be both CDN hosted by LootLocker, or a local path in your game) |
links.type_id | integer | A reference to the type of link this is |
Asset Instance Progressions
Asset Instance progression API is used to track progressions of asset instances.
You can also add or subtract points, reset or delete asset instance progressions using this API.
Starting an asset instance progression is as easy as just starting to add points.
Get Asset Instance Progressions
curl -X GET "https://api.lootlocker.io/admin/game/100/player/1/assets/instances/1/progressions?count=10&after=01GJN6J46DM00Z88WR225Y9P77"
Get list of progressions the specified asset instance is currently on. Results are always sorted by ID.
URL Structure
/admin/game/<game_id>/player/<player_id>/assets/instances/asset_instance_id/progressions
Example Response
{
"pagination": {
"next_cursor": null,
"previous_cursor": null,
"total": 2
},
"items": [
{
"id": "01GJN6J46DM00Z88WR225Y9P77",
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_key": "spring_battle_pass",
"progression_name": "Spring Battle Pass",
"step": 1,
"points": 200,
"previous_threshold": 0,
"next_threshold": null,
"last_level_up": null
},
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "summer_battle_pass",
"progression_name": "Summer Battle Pass",
"step": 3,
"points": 1300,
"previous_threshold": 1000,
"next_threshold": 2000,
"last_level_up": "2022-11-24T16:12:41Z"
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
asset_instance_id | ID of the asset instance |
Query Parameters:
Field | Description |
---|---|
after | Cursor for pagination, a cursor will be returned in the response |
count | Number of progressions returned per page. Max 500 is allowed |
Get Asset Instance Progression By ID
curl -X GET "https://api.lootlocker.io/admin/game/100/player/1/assets/instances/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF"
Get a single asset instance progression by ID.
URL Structure
/admin/game/<game_id>/player/<player_id>/assets/instances/asset_instance_id/progressions/<progression_id>
Example Response
{
"id": "01GJN6J46DM00Z88WR225Y9P77",
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_key": "spring_battle_pass",
"progression_name": "Spring Battle Pass",
"step": 1,
"points": 200,
"previous_threshold": 0,
"next_threshold": null,
"last_level_up": null
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
asset_instance_id | ID of the asset instance |
progression_id | ID of the progression |
Add points to an asset instance progression
curl -X POST "https://api.lootlocker.io/admin/game/100/player/1/assets/instances/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF/points/add" \
-d "{\"amount\": 1000 }" \
-H "Content-Type: application/json"
Adds specified amount of points to an asset instance progression. If the asset instance is not on that progression it will be automatically started.
If the asset instance leveled up, awarded_tiers fields will contain acquired rewards.
URL Structure
/admin/game/<game_id>/player/<player_id>/assets/instances/asset_instance_id/progressions/<progression_id>/points/add
Example Response
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "summer_battle_pass",
"progression_name": "Summer Battle Pass",
"step": 3,
"points": 1300,
"previous_threshold": 1000,
"next_threshold": 2000,
"last_level_up": "2022-11-24T16:12:41Z",
"awarded_tiers": [
{
"id": "01GJ34GY6XD0NGRHXV6HHVJYM9",
"step": 2,
"points_threshold": 400,
"rewards": {
"progression_points_rewards": [
{
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_name": "paragon",
"progression_key": "Paragon",
"amount": 100
}
],
"progression_reset_rewards": [
{
"progression_id": "01GJ34K7QBEB124MVE8BCFPAMG",
"progression_name": "bonus_xp",
"progression_key": "Bonus XP"
}
],
"asset_rewards": [
{
"asset_id": 2,
"asset_variation_id": null,
"asset_rental_option_id": null
}
],
"currency_rewards": [
{
"currency_id": "01HEJHRJ85PB157YV2GMHP79W1",
"currency_name": "Gold",
"currency_code": "GLD",
"amount": "100"
}
]
}
},
{
"id": "01GJ34H31MKHQD09K12WFEEQ4A",
"step": 3,
"points_threshold": 1000,
"rewards": {
"progression_points_rewards": [],
"progression_reset_rewards": [],
"asset_rewards": [],
"currency_rewards": []
}
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
asset_instance_id | ID of the asset instance |
progression_id | ID of the progression |
Available input fields
amount is required.
Field | Description |
---|---|
amount | Amount of points to be added to the asset instance's progression. |
Subtract points from an asset instance progression
curl -X POST "https://api.lootlocker.io/admin/game/100/player/1/assets/instances/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF/points/subtract" \
-d "{\"amount\": 10 }" \
-H "Content-Type: application/json"
Subtracts specified amount of points from an asset instance progression. Progression cannot go down a level, the points will be set to the previous_threshold
if too many points are being subtracted.
URL Structure
/admin/game/<game_id>/player/<player_id>/assets/instances/asset_instance_id/progressions/<progression_id>/points/subtract
Example Response
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "summer_battle_pass",
"progression_name": "Summer Battle Pass",
"step": 3,
"points": 1290,
"previous_threshold": 1000,
"next_threshold": 2000,
"last_level_up": "2022-11-24T16:12:41Z",
"awarded_tiers": []
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
asset_instance_id | ID of the asset instance |
progression_id | ID of the progression |
Available input fields
amount is required.
Field | Description |
---|---|
amount | Amount of points to be subtracted from the asset instance's progression. |
Reset an asset instance progression
curl -X POST "https://api.lootlocker.io/admin/game/100/player/1/assets/instances/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF/reset" \
-H "Content-Type: application/json"
Resets an asset instance progression. This endpoint sets the asset instance progression points to 0, so it still shows up as an active progression.
URL Structure
/admin/game/<game_id>/player/<player_id>/assets/instances/asset_instance_id/progressions/<progression_id>
Example Response
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "summer_battle_pass",
"progression_name": "Summer Battle Pass",
"step": 1,
"points": 0,
"previous_threshold": 0,
"next_threshold": 1000,
"last_level_up": null,
"awarded_tiers": []
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
asset_instance_id | ID of the asset instance |
progression_id | ID of the progression |
Delete an asset instance progression
curl -X DELETE "https://api.lootlocker.io/admin/game/100/player/1/assets/instances/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF" \
-H "Content-Type: application/json"
Deletes an asset instance progression. It won't show up in the progression list.
URL Structure
/admin/game/<game_id>/player/<player_id>/assets/instances/asset_instance_id/progressions/<progression_id>
Example Response
This endpoint will not have a body, being a
204 No Content
HTTP response.
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
asset_instance_id | ID of the asset instance |
progression_id | ID of the progression |
Asset Image Types
Asset Image Types lets you create images for use with your game, the LootLocker interface and external services such as Steam.
There are two Default Types for the Asset Image Types. They are used to determine if the file is hosted by LootLocker on our CDN or if it's a self-hosted or in-game file.
Type | Meaning | Example |
---|---|---|
0 | LootLocker CDN hosted file | https://cdn.lootlocker.io/your/file/here.png |
1 | Self-hosted or in-game file | Characters/MyTexture.tif |
A Note About Steam Integration
To enable images for Steam Inventory Service, there needs to be two Asset Image Types with specific names and their types set to 0.
The Admin interface in LootLocker will prompt you to create them if you have Steam enabled as a platform and none of them exist. If you do not want to create them that way you can use the table below to create them using the endpoints listed here.
Name | Type |
---|---|
Steam Square | 0 |
Steam Big | 0 |
List Asset Image Types
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/links"
This endpoint lists the Asset Image Types for the game you are requesting them from.
Example Response
{
"success": true,
"items": [
{
"id": 1,
"name": "My Image Type",
"type": 0,
"is_thumbnail": true
}
]
}
Get Asset Image Type
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/links/{image_type_id}"
This endpoint can be used to get a specific Asset Image Type.
{
"success": true,
"item": {
"id": 1,
"name": "My Image Type",
"type": 0,
"is_thumbnail": true
}
}
Create Asset Image Type
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/links" \
-H "Content-Type: application/json" \
-d "{\"name\": \"Image\", \"type\": 0, \"is_thumbnail\": true}"
This endpoint will create a new Asset Image Type. It takes a JSON body, with three properties.
If the is_thumbnail
property is set to true, this new Image Type will be used as the thumbnail for assets moving forward, and any existing will be set to false.
{
"success": true,
"item": {
"id": 1,
"name": "Image",
"type": 0,
"is_thumbnail": true
}
}
Update Asset Image Type
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/links/{image_type_id}" \
-H "Content-Type: application/json" \
-d "{\"name\": \"Image\", \"type\": 0, \"is_thumbnail\": true}"
This endpoint will let you update an Asset Image Type. It takes the same request body as the Create Asset Image Type endpoint.
If the is_thumbnail
property is set to true, this new Image Type will be used as the thumbnail for assets moving forward, and any existing will be set to false.
{
"success": true,
"item": {
"id": 1,
"name": "My Image Type",
"type": 0,
"is_thumbnail": true
}
}
Delete Asset Image Type
To delete an Asset Image Type, the type must have no images relying on it. If you try to delete it and it has dependents, you will get a 400 Bad Request error and an error message you can use to display in your UI.
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}/links/{image_type_id}"
Example Response
{
"success": true
}
Asset Storage Templates
Asset Storage Templates is a feature that can be used to easily add additional and shared key/value storage to your Assets. Multiple templates can be applied to the same Asset, where the least significant template is the first in the order.
List Asset Storage Templates
curl -X GET "https://api.lootlocker.io/admin/game/1/assets/templates" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
To list all Asset Storage Templates, call /admin/game/{game_id}/assets/templates
. This will return a list of templates in the format seen in the example response.
You can also opt to have data returned with the Asset Storage Template list. To do so, simply add ?includeData=true
to the end of the URL. Any Asset Storage Templates that do not have data will return an empty array.
Example Response without data
{
"items": [
{
"id": 2,
"game_id": 1,
"name": "Template Name",
}
]
}
Example Response with data
{
"items": [
{
"id": 2,
"game_id": 1,
"name": "Template Name",
"data": [
{
"key": "The Key of this entry",
"value": "The Value of this entry"
}
]
}
]
}
Get Asset Storage Template
curl -X GET "https://api.lootlocker.io/admin/game/1/assets/templates/2" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
To get a specific Asset Storage Template, call /admin/game/{game_id}/assets/templates/{template_id}
. This will return a detailed representation of the Asset Storage Template. See the example response for details.
Example Response
{
"id": 2,
"game_id": 1,
"name": "Template Name",
"data": [
{
"key": "The Key of this entry",
"value": "The Value of this entry"
},
]
}
Create Asset Storage Template
curl -X POST "https://api.lootlocker.io/admin/game/1/assets/templates" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"name\": \"Template Name\", \"data\": [{\"key\": \"A key\", \"value\": \"A value\"}]}"
To create an Asset Storage Template, use a POST
request to call /admin/game/{game_id}/assets/templates
, with the payload needed to create a new template.
Field | Required | Value |
---|---|---|
name | Yes | The name of your Asset Storage Template. Used to identify it throughout LootLocker. |
data | No | An optional array of objects with a key and value property in each for setting the data on the Asset Storage Template. |
Example Response
{
"id": 2,
"game_id": 1,
"name": "Template Name",
"data": [
{
"key": "The Key of this entry",
"value": "The Value of this entry"
},
]
}
Update Asset Storage Template
curl -X PATCH "https://api.lootlocker.io/admin/game/1/assets/templates/2" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"name\": \"Template Name\", \"data\": [{\"key\": \"Another key\", \"value\": \"Another value\"}]}"
To update an Asset Storage Template, use a PATCH
request to call https://api.lootlocker.io/admin/game/{game_id}/assets/templates/{template_id}
. The response will reflect the updated resource.
If you want to delete a KV pair, simply omit it. If you want to delete all KV pairs, send an empty array.
Example Response
{
"id": 2,
"game_id": 1,
"name": "Template Name",
"data": [
{
"key": "The Key of this entry",
"value": "The Value of this entry"
},
{
"key": "Another key",
"value": "Another value"
}
]
}
Delete Asset Storage Template
curl -X DELETE "https://api.lootlocker.io/admin/game/1/assets/templates/2" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
To delete an Asset Storage Template, use a DELETE
request to call /admin/game/{game_id}/assets/templates/{template_id}
. The response will be a 204 No Content
with no response body.
You can not delete templates on the live version of your game.
Rarities
List Asset Rarities
curl -X "https://api.lootlocker.io/admin/v1/game/{game_id}/rarity"
This endpoint will return a list of all rarities defined for your game.
The color
property is a HEX code, used to color the rarities and borders when assets are exposed to the Steam inventory and other services, as well as in the LootLocker management interface.
Example Response
{
"success": true,
"rarities": [
{
"id": 16,
"name": "Common",
"short_name": "C",
"color": "ABCDEF"
}
]
}
Create Asset Rarity
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/rarity" \
-H "Content-Type: application/json" \
-d "{\"name\": \"Legendary\", \"short_name\": \"L\", \"color\": \"ABCDEF\"}"
This endpoint will create a rarity for use with your games assets. All fields are optional and default to an empty value if not set.
Example Response
{
"success": true,
"rarity": {
"id": 18,
"name": "Legendary",
"short_name": "L",
"color": "ABCDEF"
}
}
Update Asset Rarity
curl -X "https://api.lootlocker.io/admin/v1/game/{game_id}/rarity/{rarity_id}" \
-H "Content-Type: application/json" \
-d "{\"name\": \"Legendary\", \"short_name\": \"L\", \"color\": \"FEDBCA\"}"
This endpoint is used to update a rarity. Any changes will immediately propagate to all Assets using this rarity.
{
"success": true,
"rarity": {
"id": 18,
"name": "Legendary",
"short_name": "L",
"color": "FEDBCA"
}
}
Delete Asset Rarity
curl -X "https://api.lootlocker.io/admin/v1/game/{game_id}/rarity/{rarity_id}"
This endpoint is used when you want to delete a rarity. A rarity must be empty (meaning not Assets reference it) before it can be deleted.
Example Response
{
"success": true
}
User Generated Content
Get Candidates
curl -X GET "https://api.lootlocker.io/admin/v1/game/4/assets/candidates?count=20" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Get list of asset candidates pending moderation.
Optional fields
Field | Type | Value |
---|---|---|
count | number | Number of records that should be returned |
after | number | Cursor for pagination, a cursor will be returned in the response |
order | string | Either asc or desc for ascending and descending respectively. Defaults to asc . |
Example success Response
{
"items": [
{
"id": 16,
...
}
],
"pagination": {
"total": 7,
"next_cursor": 16
}
}
Update Candidate
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/4/assets/candidate/10" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
-H "Content-Type: application/json"
-d "{\"status\": \"approve\"}"
Update asset candidate moderation status.
Fields
Field | Type | Value |
---|---|---|
status | string | Required: approve or deny |
comment | string | Optional comment, only used when denying an asset candidate |
Example success Response
{
"success": true
}
Characters
Characters are a core concept in LootLocker, and each player needs to have at least one to be able to equip assets. Characters can also be extended with extra functionality through the Heroes feature.
Through the Admin API you can configure your Character Classes.
There is currently a bit of confusion in the naming for Character Classes, as they were previously called Character Types in LootLocker, so any references to Character Types actually refer to Character Classes too. This will be fixed in upcoming v2 endpoints.
List Character Classes
curl -X GET "https://api.lootlocker.io/admin/v1/game/1234/loadout/default" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
To list all Character Classes configured for a game, call this endpoint, substituting 1234
for your games ID.
Example Response
{
"success": true,
"character_types": [
{
"default": false,
"name": "Medic",
"id": 3,
"contexts": [],
"storage": []
},
{
"default": true,
"name": "Heavy",
"id": 1,
"contexts": [
{
"name": "Barks",
"default_loadout_asset": {
"name": "Quick Angry",
"image": null,
"variation_name": ""
}
}
],
"storage": [
{
"key": "custom_data",
"value": "value"
}
]
}
]
}
Under the character_types
property of a successful response, you will find the following structure:
Property | Meaning |
---|---|
default | Is this the default character class for newly created characters |
name | The name of your character class |
id | The ID of the character class |
contexts | An array of contexts this character class can equip assets from |
contexts.name | The name of the context |
contexts.default_loadout_asset | Structure for presenting asset information |
contexts.default_loadout_asset.name | The name of the default asset for this context |
contexts.default_loadout_asset.image | A URL to an image for this asset if one exists |
contexts.default_loadout_asset.variation_name | The variation name for this asset if it exists and was selected |
storage | An array of key/value pairs |
storage.key | The key of the pair |
storage.value | The value of the pair |
Update Character Type
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/1234/loadout/default/5678" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-d "{\"name\": \"Heavy\", \"default\": false}"
To update a Character Type or it's default loadout, send a request to this endpoint, substituting 1234
for your games ID, and 5678
for the Character Type's ID.
If you wish to delete the default_loadout_asset
, simply update with that key's value set to null
.
If you wish to change or set the default_loadout_asset
, instead set two properties: asset_id
and variation_id
if the asset has variations.
When changing a Default Character Type, using the default
boolean, you do not need to both remove and add the status to both Character Types. LootLocker will automatically ensure that only the newly appointed default Character Type is default.
Creating a new Character Type is done by setting the Character Type ID to new
instead of an integer.
Example Payload
{
"default":true,
"name":"Heavy",
"contexts":[
{
"name":"Barks",
"default_loadout_asset": {
"asset_id":2,
"variation_id":null,
}
}
]
}
The response from this call is the same as from List Character Classes.
Delete Character Type
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/1234/loadout/default/5678"
Character Types can only be deleted if they haven't been used to create a player character in your game. If player characters exist in your game, you will see the error in the Example Error Response
.
A successful deletion will immediately remove the Character Type, as well as any Default Loadout that may have been configured for it.
Example Error Response
{
"success": false,
"error": "Instances of this character type exists, and because of that it can't be deleted"
}
Example Success Response
{
"success": true
}
Character Progressions
Character progression API is used to track your player's specific characters progress on your game's progressions.
You can also add or subtract points, reset or delete character's progressions using this API.
Starting a character on a progression is as easy as just starting to add points to it.
Get Character Progressions
curl -X GET "https://api.lootlocker.io/admin/game/100/player/1/characters/1/progressions?count=10&after=01GJN6J46DM00Z88WR225Y9P77"
Get list of progressions the specified character is currently on. Results are always sorted by ID.
URL Structure
/admin/game/<game_id>/player/<player_id>/characters/<character_id>/progressions
Example Response
{
"pagination": {
"next_cursor": null,
"previous_cursor": null,
"total": 2
},
"items": [
{
"id": "01GJN6J46DM00Z88WR225Y9P77",
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_key": "fighter",
"progression_name": "fighter",
"step": 1,
"points": 200,
"previous_threshold": 0,
"next_threshold": null,
"last_level_up": null
},
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "mage",
"progression_name": "mage",
"step": 3,
"points": 1300,
"previous_threshold": 1000,
"next_threshold": 2000,
"last_level_up": "2022-11-24T16:12:41Z"
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
character_id | ID of the character |
Query Parameters:
Field | Description |
---|---|
after | Cursor for pagination, a cursor will be returned in the response |
count | Number of progressions returned per page. Max 500 is allowed |
Get Character Progression By ID
curl -X GET "https://api.lootlocker.io/admin/game/100/player/1/characters/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF"
Get a single character progression by ID.
URL Structure
/admin/game/<game_id>/player/<player_id>/characters/<character_id>/progressions/<progression_id>
Example Response
{
"id": "01GJN6J46DM00Z88WR225Y9P77",
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_key": "fighter",
"progression_name": "fighter",
"step": 1,
"points": 200,
"previous_threshold": 0,
"next_threshold": null,
"last_level_up": null
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
character_id | ID of the character |
progression_id | ID of the progression |
Add points to a character progression
curl -X POST "https://api.lootlocker.io/admin/game/100/player/1/characters/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF/points/add" \
-d "{\"amount\": 1000 }" \
-H "Content-Type: application/json"
Adds specified amount of points to a character progression. If the character is not on that progression it will be automatically started.
If the character leveled up, awarded_tiers fields will contain acquired rewards.
URL Structure
/admin/game/<game_id>/player/<player_id>/characters/<character_id>/progressions/<progression_id>/points/add
Example Response
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "mage",
"progression_name": "mage",
"step": 3,
"points": 1300,
"previous_threshold": 1000,
"next_threshold": 2000,
"last_level_up": "2022-11-24T16:12:41Z",
"awarded_tiers": [
{
"id": "01GJ34GY6XD0NGRHXV6HHVJYM9",
"step": 2,
"points_threshold": 400,
"rewards": {
"progression_points_rewards": [
{
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_name": "fighter",
"progression_key": "fighter",
"amount": 100
}
],
"progression_reset_rewards": [
{
"progression_id": "01GJ34K7QBEB124MVE8BCFPAMG",
"progression_name": "rogue",
"progression_key": "rogue"
}
],
"asset_rewards": [
{
"asset_id": 2,
"asset_variation_id": null,
"asset_rental_option_id": null
}
],
"currency_rewards": [
{
"currency_id": "01HEJHRJ85PB157YV2GMHP79W1",
"currency_name": "Gold",
"currency_code": "GLD",
"amount": "100"
}
]
}
},
{
"id": "01GJ34H31MKHQD09K12WFEEQ4A",
"step": 3,
"points_threshold": 1000,
"rewards": {
"progression_points_rewards": [],
"progression_reset_rewards": [],
"asset_rewards": [],
"currency_rewards": []
}
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
character_id | ID of the character |
progression_id | ID of the progression |
Available input fields
amount is required.
Field | Description |
---|---|
amount | Amount of points to be added to the character's progression. |
Subtract points from a character progression
curl -X POST "https://api.lootlocker.io/admin/game/100/player/1/characters/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF/points/subtract" \
-d "{\"amount\": 10 }" \
-H "Content-Type: application/json"
Subtracts specified amount of points from a character progression. The character cannot go down a progression step, the points will be set to the previous_threshold if too many points are being subtracted.
URL Structure
/admin/game/<game_id>/player/<player_id>/characters/<character_id>/progressions/<progression_id>/points/subtract
Example Response
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "mage",
"progression_name": "mage",
"step": 3,
"points": 1290,
"previous_threshold": 1000,
"next_threshold": 2000,
"last_level_up": "2022-11-24T16:12:41Z",
"awarded_tiers": []
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
character_id | ID of the character |
progression_id | ID of the progression |
Available input fields
amount is required.
Field | Description |
---|---|
amount | Amount of points to be subtracted from the character's progression. |
Reset a character progression
curl -X POST "https://api.lootlocker.io/admin/game/100/player/1/characters/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF/reset" \
-H "Content-Type: application/json"
Resets a character progression. This endpoint sets the character progression points to 0, so it still shows up as an active progression.
URL Structure
/admin/game/<game_id>/player/<player_id>/characters/<character_id>/progressions/<progression_id>
Example Response
{
"id": "01GJN6JGK3AV0N8YJ9GHSCJ4D3",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"progression_key": "mage",
"progression_name": "mage",
"step": 1,
"points": 0,
"previous_threshold": 0,
"next_threshold": 1000,
"last_level_up": null,
"awarded_tiers": []
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
character_id | ID of the character |
progression_id | ID of the progression |
Delete a character progression
curl -X DELETE "https://api.lootlocker.io/admin/game/100/player/1/characters/1/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF" \
-H "Content-Type: application/json"
Deletes a character progression. It won't show up in character's active progression list.
URL Structure
/admin/game/<game_id>/player/<player_id>/characters/<character_id>/progressions/<progression_id>
Example Response
This endpoint will not have a body, being a
204 No Content
HTTP response.
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player |
character_id | ID of the character |
progression_id | ID of the progression |
Heroes
Heroes are an extension of the Characters functionality, which add extra functionality on top.
List Heroes
curl -X GET "https://api.lootlocker.io/admin/v1/game/2/heroes" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Listing heroes to a game is done by calling this endpoint. Very little information about each hero is returned here. Only what's needed to build a simple interface where you can inspect a hero more closely later, using the Get Hero endpoint.
Example Response
{
"success": true,
"heroes": [
{
"name": "Rick Astley",
"hero_id": 3,
"asset_id": 5,
"character_type_id": 4,
"character_type_name": "Medic",
"exception_count": 0,
"default_loadout": [
{
"id": 3,
"live_hero_default_loadout_id": 2,
"hero_id": 2,
"asset_id": 298778,
"asset_variation_id": null,
"created_at": "2023-09-13 17:18:37",
"updated_at": "2023-09-13 17:18:37",
"thumbnail": "https://cdn.lootlocker.io/..."
}
]
}
]
}
Get Hero
curl -X GET "https://api.lootlocker.io/admin/v1/game/2/heroes/3" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint lets you get more information about a hero, than you get when you list them all.
This endpoint also returns the default loadout and equipping exceptions a hero has set up.
Example Response
{
"success": true,
"hero": {
"name": "Rick Astley",
"hero_id": 3,
"asset_id": 5,
"character_type_id": 4,
"character_type_name": "Medic",
"default_loadout": [
{
"id": 4,
"asset_id": 2,
"asset_variation_id": null,
"thumbnail": "https://cdn.lootlocker.io/...",
"created_at": "Mon Nov 30 2020 15:28:41 GMT+0000",
"updated_at": "Mon Nov 30 2020 15:28:41 GMT+0000"
}
],
"exceptions": []
}
}
Create Hero
curl -X POST "https://api.lootlocker.io/admin/v1/game/2/heroes" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-d "{\"name\": \"David Hasselhoff\", \"character_type_id\": 2}"
Example Response
{
"success": true,
"hero": {
"name": "David Hasselhoff",
"hero_id": 3,
"asset_id": 4,
"character_type_id": 2,
"character_type_name": "Medic",
"default_loadout": [],
"exceptions": []
}
}
Update Hero
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/2/heroes/3" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-d "{\"name\": \"Rick Astley\"}"
Example Response
{
"success": true,
"hero": {
"name": "Rick Astley",
"hero_id": 3,
"asset_id": 4,
"character_type_id": 2,
"character_type_name": "Medic",
"default_loadout": [],
"exceptions": []
}
}
Delete Hero
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/2/heroes/3"
Deleting a hero can be done by calling this endpoint.
Example Response
{
"success": true
}
Adding an Asset to a Heroes Default Loadout
curl -x POST "https://api.lootlocker.io/admin/v1/game/2/heroes/3/defaults" \
-d "{\"asset_id\": 2, \"asset_variation_id\": 4}"
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
When adding to a heroes default loadout, you can supply only an asset_id
, or an asset_id
with a corresponding asset_varaiation_id
. If no asset_variation_id
is supplied, the default variation for the asset is used, if it has any variations, however, the property is left empty, and the default variation is evaluated when the player creates the hero.
Example Response
{
"success": true,
"hero": {
"name": "Rick Astley",
"hero_id": 3,
"asset_id": 5,
"character_type_id": 4,
"character_type_name": "Medic",
"default_loadout": [
{
"id": 4,
"asset_id": 2,
"asset_variation_id": null,
"thumbnail": "https://cdn.lootlocker.io/...",
"created_at": "Mon Nov 30 2020 15:28:41 GMT+0000",
"updated_at": "Mon Nov 30 2020 15:28:41 GMT+0000"
}
],
"exceptions": []
}
}
Removing an Asset from a Heroes Default Loadout
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/2/heroes/3/defaults/4" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Example Response
{
"success": true,
"hero": {
"name": "Rick Astley",
"hero_id": 3,
"asset_id": 5,
"character_type_id": 4,
"character_type_name": "Medic",
"default_loadout": [],
"exceptions": []
}
}
Adding an Asset or a Context to a Heroes Exception List
curl -X POST "https://api.lootlocker.io/admin/v1/heroes/3/exceptions" \
-d "" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
The exception list for a Hero is a list that can be used to make exceptions to the Hero's default equippable items (inherited from the Character Type).
Example Response
{
"success": true,
"hero": {
"name": "Rick Astley",
"hero_id": 5,
"character_type_id": 2,
"default_loadout": [],
"exceptions": [
{
"id": 2,
"asset_id": 2,
"context_id": null,
"can_equip": true,
"created_at": "Tue Dec 1 2020 09:10:41 GMT+0000",
"updated_at": "Tue Dec 1 2020 09:10:41 GMT+0000"
}
]
}
}
Removing an Asset or a Context from a Heroes Exception List
curl -X DELETE "https://api.lootlocker.io/admin/v1/heroes/3/exceptions/1234" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Example Response
{ "success": true }
Leaderboards
In the context of the admin API, leaderboards can be used to create/update/delete leaderboards but also moderate scores and members. To read more about leaderboards in general you can read our Leaderboard Product Documentation.
An entry on a leaderboard is called a member. Since it's possible to have leaderboards for all kinds of cases it doesn't make sense to use players here.
Because of that member_id
can be whatever you want as long as it makes sense in your game. For lots of cases using the players ID will make good sense, but you can imagine a case where you would rank different clans/guilds against each other for example. In that case you would use clan/guild ID as member_id
.
When using a leaderboard ID in any url it's possible to replace this with the key set on the leaderboard instead.
Leaderboard Types
Generic leaderboards
Use this if you want do not want the extended player details from the player type leaderboard. This type allows you to create leaderboards not meant for players (guild/clan for example), or if your player data is not stored in LootLocker.
Player leaderboards
Meant for LootLocker players leaderboards. When submitting scores you must use player_id
as member_id
, but when retrieving data LootLocker will automatically attach player data such as name.
Metadata
Sometimes you want to store more data alongside the score for each entry on the leaderboard.
To accomplish this you can enable metadata on the leaderboard at the time of creation.
When submitting scores to that leaderboard you can send the metadata
property with a string value in the request and that value will be automatically returned for that score entry.
Get Leaderboards
curl -X GET "https://api.lootlocker.io/admin/game/100/leaderboards?count=10&after=1"
Get list of leaderboards. Results are always sorted by ID.
URL Structure
/admin/game/<game_id>/leaderboards?count=10&after=0
Example Response
{
"pagination": {
"total": 20,
"next_cursor": 2,
"previous_cursor": null
},
"items": [
{
"id": 1,
"key": "some key",
"created_at": "2021-03-11T08:53:06Z",
"updated_at": "2021-03-11T08:53:06Z",
"direction_method": "descending",
"enable_game_api_writes": true,
"overwrite_score_on_submit": false,
"has_metadata": true,
"game_id": 100,
"name": "Player Leaderboard",
"type": "player"
},
{
"id": 2,
"key": "some_other_key",
"created_at": "2021-03-11T13:29:25Z",
"updated_at": "2021-03-11T13:29:25Z",
"direction_method": "ascending",
"enable_game_api_writes": false,
"overwrite_score_on_submit": false,
"has_metadata": false,
"game_id": 100,
"name": "Guild Leaderboard",
"type": "generic"
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
Query Parameters:
Field | Description |
---|---|
after | Cursor for pagination, a cursor will be returned in the response |
count | Number of leaderboards returned per page. Max 500 is allowed |
Get Leaderboard By ID
curl -X GET "https://api.lootlocker.io/admin/game/100/leaderboards/1"
Get a single leaderboard by ID.
URL Structure
/admin/game/<game_id>/leaderboards/<leaderboard_id>
Example Response
{
"id": 1,
"key": "some key",
"created_at": "2021-03-11T08:53:06Z",
"updated_at": "2021-03-11T08:53:06Z",
"direction_method": "descending",
"enable_game_api_writes": true,
"overwrite_score_on_submit": false,
"has_metadata": true,
"game_id": 100,
"name": "Player Leaderboard",
"type": "player"
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
leaderboard_id | ID of the leaderboard |
Create Leaderboard
curl -X POST "https://api.lootlocker.io/admin/game/100/leaderboards" \
-d "{\"name\": \"Global Leaderboard\", \"key\": \"some_third_key\", \"direction_method\": \"descending\", \"enable_game_api_writes\": false, \"overwrite_score_on_submit\": false, \"has_metadata\": true, \"type\": \"generic\"}" \
-H "Content-Type: application/json"
Create a new leaderboard.
URL Structure
/admin/game/<game_id>/leaderboards
Example Response
{
"id": 3,
"key": "some_third_key",
"created_at": "2021-03-16T09:08:46.387539986Z",
"updated_at": "2021-03-16T09:08:46.387539986Z",
"direction_method": "descending",
"enable_game_api_writes": false,
"overwrite_score_on_submit": false,
"has_metadata": true,
"game_id": 100,
"name": "Global Leaderboard",
"type": "generic"
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
Available input fields
All fields are required.
Field | Description |
---|---|
name | Name of your leaderboard, used primarily in admin |
key | Optional unique key, can be used to retrieve the leaderboard later |
type | player/generic depending on your use case |
direction_method | Can only be ascending/descending, based on whether higher rank is lowest or highest number |
enable_game_api_writes | Enable Game API to submit scores |
overwrite_score_on_submit | Submitting a new score for member will always overwrite their existing score on leaderboard |
has_metadata | Enable submitting metadata along side the score for more data on each entry. Not possible to change later. |
Update Leaderboard
curl -X PUT "https://api.lootlocker.io/admin/game/100/leaderboards/3" \
-d "{\"name\": \"Global Leaderboard 2\", \"key\": \"some_third_key\", \"direction_method\": \"ascending\", \"enable_game_api_writes\": true, \"overwrite_score_on_submit\": true}" \
-H "Content-Type: application/json"
URL Structure
/admin/game/<game_id>/leaderboards/<leaderboard_id|leaderboard_key>
Example Response
{
"id": 3,
"key": "some_third_key",
"created_at": "2021-03-16T09:08:46.387539986Z",
"updated_at": "2021-03-16T09:11:32.031258686Z",
"direction_method": "ascending",
"enable_game_api_writes": true,
"overwrite_score_on_submit": true,
"has_metadata": true,
"game_id": 100,
"name": "Global Leaderboard 2",
"type": "generic"
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
leaderboard_id | ID of the leaderboard |
leaderboard_key | key of the leaderboard |
Available input fields
All fields are optional.
Field | Description |
---|---|
name | Name of your leaderboard, used primarily in admin |
key | Optional unique key, can be used to retrieve the leaderboard later |
type | player/generic depending on your use case |
direction_method | Can only be ascending/descending, based on whether higher rank is lowest or highest number |
enable_game_api_writes | Enable Game API to submit scores |
overwrite_score_on_submit | Submitting a new score for member will always overwrite their existing score on leaderboard |
Delete Leaderboard
curl -X DELETE "https://api.lootlocker.io/admin/game/100/leaderboards/3"
Soft delete a leaderboard. It will no longer be possible to submit scores to that leaderboard.
URL Structure
/admin/game/<game_id>/leaderboards/<leaderboard_id|leaderboard_key>
Example Response
Versions after
2021-06-01
will return a 204 status code with no response bodyVersions prior to
2021-06-01
:
{
"id": 3,
"key": "some_third_key",
"created_at": "2021-03-16T09:08:46.387539986Z",
"updated_at": "2021-03-16T09:11:32.031258686Z",
"direction_method": "ascending",
"enable_game_api_writes": true,
"overwrite_score_on_submit": true,
"has_metadata": true,
"game_id": 100,
"name": "Global Leaderboard 2",
"type": "generic"
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
leaderboard_id | ID of the leaderboard |
leaderboard_key | key of the leaderboard |
Delete Member
curl -X DELETE "https://api.lootlocker.io/admin/game/1/leaderboards/5/member/game_test_player_id"
Permanently removes a member from a leader board. Their entry + score will be removed. They can still submit new scores to that leaderboard.
URL Structure
/admin/game/<game_id>/leaderboards/<leaderboard_id|leaderboard_key>/member/<member_id>
Example Response
{
"success": true
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
leaderboard_id | ID of the leaderboard |
leaderboard_key | key of the leaderboard |
member_id | player_id if player type leaderboard, otherwise id used when submitting the score |
Update Member Score
curl -X PUT "https://api.lootlocker.io/admin/game/1/leaderboards/5/member/1" \
-d "{\"score\": 1233}" \
-H "Content-Type: application/json"
Update the score for a member of a leaderboard. This ignores overwrite_score_on_submit
on the leaderboard and overwrites the score no matter what.
If metadata is enabled for the leaderboard, that will be returned in the response.
URL Structure
/admin/game/<game_id>/leaderboards/<leaderboard_id|leaderboard_key>/member/<member_id>
Example Response
{
"member_id": "1",
"rank": 3,
"score": 1233,
"metadata": "some metadata"
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
leaderboard_id | ID of the leaderboard |
leaderboard_key | key of the leaderboard |
member_id | player_id if player type leaderboard, otherwise id used when submitting the score |
Get Member Rank
curl -X GET "https://api.lootlocker.io/admin/game/1/leaderboards/5/member/1"
Get rank for single member for a leaderboard. If leaderboard is of type player
a player will also be in the response.
If metadata is enabled for the leaderboard, that will be returned in the response.
URL Structure
/admin/game/<game_id>/leaderboards/<leaderboard_id|leaderboard_key>/member/<member_id>
Example Response
{
"member_id": "1",
"rank": 3,
"score": 3004,
"player": {
"id": 1,
"public_uid": "TSEYDXD8",
"name": "Player Name"
},
"metadata": "some metadata"
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
leaderboard_id | ID of the leaderboard |
leaderboard_key | key of the leaderboard |
member_id | player_id if player type leaderboard, otherwise id used when submitting the score |
Get All Member Ranks
curl -X GET "https://api.lootlocker.io/admin/game/1/leaderboards/member/4?count=1
Get all leaderboards with member information on the ones the member is on, with rank and score, as well as player information if the leaderboard is of type player
.
If metadata is enabled for the leaderboard, that will be returned in the response.
URL Structure
/admin/game/<game_id>/leaderboards/member/<member_id>?count=1&after=0
Example Response
{
"leaderboards": [
{
"rank": {
"rank": 1,
"member_id": "4",
"score": 134076416,
"player": {
"name": "Player Name",
"id": 4,
"public_uid": "ABCD1234"
},
"metadata": "some metadata"
},
"leaderboard_id": 1,
"leaderboard_key": "LeaderboardKey"
}
],
"pagination": {
"total": 100,
"next_cursor": "2",
"previous_cursor": null
}
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
member_id | player_id if player type leaderboard, otherwise id used when submitting the score |
Query Parameters
Field | Description |
---|---|
after | Cursor for pagination, a cursor will be returned in the response |
count | Number of members returned per page |
Get Score List
curl -X GET "https://api.lootlocker.io/admin/game/1/leaderboards/10/list?count=3"
Get list of members in rank range.
Maximum allowed members to query for at a time is currently 500.
If leaderboard is of type player
a player will also be in the response.
If metadata is enabled for the leaderboard, that will be returned in the response.
URL Structure
/admin/game/<game_id>/leaderboards/<leaderboard_id|leaderboard_key>/list?count=3&after=0
Example Response
{
"pagination": {
"total": 5,
"next_cursor": "3",
"previous_cursor": null
},
"items": [
{
"member_id": "1",
"rank": 1,
"score": 10000,
"player": {
"id": 1,
"public_uid": "TSEYDXD8",
"name": "Player Name"
},
"metadata": "some metadata"
},
{
"member_id": "2",
"rank": 2,
"score": 9999,
"player": {...},
"metadata": "some metadata"
},
{
"member_id": "3",
"rank": 3,
"score": 7500,
"player": {...},
"metadata": "some metadata"
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
leaderboard_id | ID of the leaderboard |
leaderboard_key | key of the leaderboard |
Query Parameters
Field | Description |
---|---|
after | Cursor for pagination, a cursor will be returned in the response |
count | Number of members returned per page |
Progressions
Progressions API allows you to create new progressions, update existing progressions, as well as their progression tiers and rewards.
Progressions can be used to track player progress, ranging from player levels, class levels, achievements, battle passes and everything in between.
Your game can have as many progressions as you need and your players can progress through as many as your game requires them to, possibilities are endless.
Get All Progressions
curl -X GET "https://api.lootlocker.io/admin/game/100/progressions?count=10&after=01GJ34JX0VKJKM4P6X9JHZ8FDF"
Get a list of all progressions. Results are always sorted by ID.
URL Structure
/admin/game/<game_id>/progressions
Example Response
{
"pagination": {
"total": 20,
"next_cursor": null,
"previous_cursor": null
},
"items": [
{
"id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"key": "warrior",
"name": "warrior",
"game_id": 100,
"active": true,
"allow_game_writes": true
},
{
"id": "01GJ34969HM62X7DWTQ0QWEXVP",
"key": "mage",
"name": "mage",
"game_id": 100,
"active": true,
"allow_game_writes": true
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
Query Parameters:
Field | Description |
---|---|
after | Cursor for pagination, a cursor will be returned in the response |
count | Number of progressions returned per page. Max 500 is allowed |
Get Progression By ID
curl -X GET "https://api.lootlocker.io/admin/game/100/progressions/01GJ34JX0VKJKM4P6X9JHZ8FDF"
Get a single progression by ID.
URL Structure
/admin/game/<game_id>/progressions/<progression_id>
Example Response
{
"id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"key": "warrior",
"name": "warrior",
"game_id": 100,
"active": true,
"allow_game_writes": true
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
progression_id | ID of the progression |
Create a progression
curl -X POST "https://api.lootlocker.io/admin/game/100/progressions" \
-d "{\"name\": \"rogue\", \"key\": \"rogue\", \"active\": true, \"allow_game_writes\": true }" \
-H "Content-Type: application/json"
Create a new progression.
URL Structure
/admin/game/<game_id>/progressions
Example Response
{
"id": "01GJ34K7QBEB124MVE8BCFPAMG",
"key": "rogue",
"name": "rogue",
"game_id": 100,
"active": true,
"allow_game_writes": true
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
Available input fields
If name or key are not sent, we will generate them for the progression, you can always change them later.
Field | Description |
---|---|
name | Name of your progression, can be used for displaying a prettified name in your Game UI. |
key | Unique key, used for interacting with progression from the Game and Server APIs. |
active | Inactive progressions cannot be used from the Game and Server APIs. |
allow_game_writes | Controls if Game API is allowed to interact with the progression from the game Client |
Update progression
Update an existing progression.
curl -X PUT "https://api.lootlocker.io/admin/game/100/progressions/3" \
-d "{\"name\": \"rogue\", \"key\": \"rogue\", \"active\": true, \"allow_game_writes\": true }" \
-H "Content-Type: application/json"
URL Structure
/admin/game/<game_id>/progressions/<progression_id|progression_key>
Example Response
{
"id": "01GJ34K7QBEB124MVE8BCFPAMG",
"key": "rogue",
"name": "rogue",
"game_id": 100,
"active": true,
"allow_game_writes": true
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
progression_id | ID of the progression |
Available input fields
If name or key are not sent, we will generate them for the progression, you can always change them later.
Field | Description |
---|---|
name | Name of your progression, can be used for displaying a prettified name in your Game UI. |
key | Unique key, used for interacting with progression from the Game and Server APIs. |
active | Inactive progressions cannot be used from the Game and Server APIs. |
allow_game_writes | Controls if Game API is allowed to interact with the progression from the game Client |
Get Progressions Tiers
curl -X GET "https://api.lootlocker.io/admin/game/100/progressions/01GJ34969HM62X7DWTQ0QWEXVP/tiers?count=10&after=1"
Get list of tiers for the progression and their rewards. Results are always sorted by progression tier step in ascending order.
Note that for pagination the step is used as the cursor instead of the ID.
URL Structure
/admin/game/<game_id>/progressions/<progression_id>?count=10&after=0
Example Response
{
"pagination": {
"next_cursor": null,
"previous_cursor": null,
"total": 5
},
"items": [
{
"id": "01GJ34969N84J32MG8WHTBYM84",
"step": 1,
"points_threshold": 0,
"rewards": {
"progression_points_rewards": [],
"progression_reset_rewards": [],
"asset_rewards": []
}
},
{
"id": "01GJ34GY6XD0NGRHXV6HHVJYM9",
"step": 2,
"points_threshold": 1000,
"rewards": {
"progression_points_rewards": [
{
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_key": "fighter",
"progression_name": "fighter",
"amount": 100
}
],
"progression_reset_rewards": [
{
"progression_id": "01GJ34K7QBEB124MVE8BCFPAMG",
"progression_key": "rogue",
"progression_name": "rogue"
}
],
"asset_rewards": [
{
"asset_id": 2,
"asset_variation_id": null,
"asset_rental_option_id": null
}
],
"currency_rewards": [
{
"currency_id": "01HEJHRJ85PB157YV2GMHP79W1",
"currency_name": "Gold",
"currency_code": "GLD",
"amount": "100"
}
]
}
},
{
"id": "01GJ34H31MKHQD09K12WFEEQ4A",
"step": 3,
"points_threshold": 3000,
"rewards": {
"progression_points_rewards": [],
"progression_reset_rewards": [],
"asset_rewards": [
{
"asset_id": 3,
"asset_variation_id": null,
"asset_rental_option_id": null
}
],
"currency_rewards": []
}
},
{
"id": "01GJ34H54CVVRXHX44C4VXSBCX",
"step": 4,
"points_threshold": 5000,
"rewards": {
"progression_points_rewards": [
{
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_key": "fighter",
"progression_name": "fighter",
"amount": 100
}
],
"progression_reset_rewards": [],
"asset_rewards": [],
"currency_rewards": []
}
},
{
"id": "01GJ34H686XFZDFR205BPXXZHH",
"step": 5,
"points_threshold": 10000,
"rewards": {
"progression_points_rewards": [],
"progression_reset_rewards": [],
"asset_rewards": [],
"currency_rewards": []
}
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
progression_id | ID of the progression |
Query Parameters:
Field | Description |
---|---|
after | Cursor for pagination, a cursor will be returned in the response |
count | Number of progressions returned per page. Max 500 is allowed |
Get Progression Tier By ID
curl -X GET "https://api.lootlocker.io/admin/game/100/progressions/01GJ34969HM62X7DWTQ0QWEXVP/tiers/01GJ34GY6XD0NGRHXV6HHVJYM9"
Get a single progression tier by ID including it's rewards.
URL Structure
/admin/game/<game_id>/progressions/<progression_id>/tiers/<progression_tier_id>
Example Response
{
"id": "01GJ34GY6XD0NGRHXV6HHVJYM9",
"step": 2,
"points_threshold": 1000,
"rewards": {
"progression_points_rewards": [
{
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_key": "fighter",
"progression_name": "fighter",
"amount": 100
}
],
"progression_reset_rewards": [
{
"progression_id": "01GJ34K7QBEB124MVE8BCFPAMG",
"progression_key": "rogue",
"progression_name": "rogue"
}
],
"asset_rewards": [
{
"asset_id": 2,
"asset_variation_id": null,
"asset_rental_option_id": null
}
],
"currency_rewards": [
{
"currency_id": "01HEJHRJ85PB157YV2GMHP79W1",
"currency_name": "Gold",
"currency_code": "GLD",
"amount": "100"
}
]
}
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
progression_id | ID of the progression |
progression_tier_id | ID of the progression tier |
Create progression tier
curl -X POST "https://api.lootlocker.io/admin/game/100/progressions/01GJ34969HM62X7DWTQ0QWEXVP/tiers/" \
-d "{\"step\": 6, \"points_threshold\": 4000 }" \
-H "Content-Type: application/json"
Create a new progression tier.
URL Structure
/admin/game/<game_id>/progressions/<progression_id>/tiers
Example Response
{
"id": "01GJN2C57ZN503TNJ53T72B8BY",
"step": 6,
"points_threshold": 4000,
"rewards": {
"progression_points_rewards": [],
"progression_reset_rewards": [],
"asset_rewards": [],
"currency_rewards": []
}
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
progression_id | ID of the progression |
Available input fields
step is optional and if not sent, the tier will be added at the end. If the step is specified all the tiers that are above it will be bumped up a step. points_threshold is required.
Field | Description |
---|---|
step | Progression step being added, defaults to current max step + 1 if omitted |
points_threshold | Points threshold needed to reach this step in the progression |
Update progression tier
curl -X PUT "https://api.lootlocker.io/admin/game/100/progressions/01GJ34969HM62X7DWTQ0QWEXVP/tiers/01GJN2C57ZN503TNJ53T72B8BY" \
-d "{\"points_threshold\": 5000 }" \
-H "Content-Type: application/json"
Update a progression tier.
URL Structure
/admin/game/<game_id>/progressions/<progression_id>/tiers/<progression_tier_id>
Example Response
{
"id": "01GJN2C57ZN503TNJ53T72B8BY",
"progression_id": "01GJ34969HM62X7DWTQ0QWEXVP",
"step": 6,
"points_threshold": 5000,
"rewards": {
"progression_points_rewards": [],
"progression_reset_rewards": [],
"asset_rewards": [],
"currency_rewards": []
}
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
progression_id | ID of the progression |
progression_tier_id | ID of the progression tier |
Available input fields
points_threshold is required.
Field | Description |
---|---|
points_threshold | Points threshold needed to reach this step in the progression |
Update Progression Tier Rewards
curl -X PUT "https://api.lootlocker.io/admin/game/100/progressions/01GJ34969HM62X7DWTQ0QWEXVP/tiers/01GJN2C57ZN503TNJ53T72B8BY/rewards" \
-d "{ \"progression_points_rewards\": [{ \"progression_id\": \"01GJ34JX0VKJKM4P6X9JHZ8FDF\", \"amount\": 100 }], \"progression_reset_rewards\": [{ \"progression_id\": \"01GJ34K7QBEB124MVE8BCFPAMG\" }], \"asset_rewards\": [{ \"asset_id\": 2, \"asset_variation_id\": null, \"asset_rental_option_id\": null }], \"currency_rewards\": [{ \"currency_id\": \"01HEJHRJ85PB157YV2GMHP79W1\", \"amount\": 100 }]}" \
-H "Content-Type: application/json"
Update rewards for a progression tier.
URL Structure
/admin/game/<game_id>/progressions/<progression_id>/tiers/<progression_tier_id>/rewards
Example Response
{
"progression_points_rewards": [
{
"progression_id": "01GJ34JX0VKJKM4P6X9JHZ8FDF",
"progression_key": "fighter",
"progression_name": "fighter",
"amount": 100
}
],
"progression_reset_rewards": [
{
"progression_id": "01GJ34K7QBEB124MVE8BCFPAMG",
"progression_key": "rogue",
"progression_name": "rogue"
}
],
"asset_rewards": [
{
"asset_id": 2,
"asset_variation_id": null,
"asset_rental_option_id": null
}
],
"currency_rewards": [
{
"currency_id": "01HEJHRJ85PB157YV2GMHP79W1",
"currency_name": "Gold",
"currency_code": "GLD",
"amount": "100"
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
progression_id | ID of the progression |
progression_tier_id | ID of the progression tier |
Available input fields
Sending an empty list of rewards clears all rewards for that tier.
progression_points_rewards
Field | Description |
---|---|
progression_id | ID of the progression that should be awarded points when this tier is reached. |
amount | Amount of points that should be awarded points when this tier is reached. |
progression_reset_rewards
Field | Description |
---|---|
progression_id | ID of the progression that should be reset when this tier is reached. |
asset_rewards
Field | Description |
---|---|
asset_id | ID of the asset that should be awarded when this tier is reached. |
asset_variation_id | Optional asset variation. |
asset_rental_option_id | Optional asset rental option. |
currency_rewards
Field | Description |
---|---|
currency_id | ID of the currency that should be awarded when this tier is reached. |
amount | Amount of currency that should be awarded points when this tier is reached. |
Delete a progression tier
curl -X DELETE "https://api.lootlocker.io/admin/game/100/progressions/01GJ34969HM62X7DWTQ0QWEXVP/tiers/01GJN2C57ZN503TNJ53T72B8BY" \
-H "Content-Type: application/json"
Deletes a progression tier. All progression tiers after this tier will have their step decremented by 1.
URL Structure
/admin/game/<game_id>/progressions/<progression_id>/tiers/<progression_tier_id>
Example Response
This endpoint will not have a body, being a
204 No Content
HTTP response.
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
progression_id | ID of the progression |
progression_tier_id | ID of the progression tier |
Get Diff
curl -X GET "https://api.lootlocker.io/admin/game/100/progressions/diff"
Get the diff tree for merging purposes.
URL Structure
/admin/game/<game_id>/progressions/diff
Example Response
{
"fighter":{
"id":"01GJ34JX0VKJKM4P6X9ND3G5X2",
"entity_id":{
"original":null,
"new":"01GJ34JX0VKJKM4P6X9JHZ8FDF"
},
"operation":"Create progression",
"values":[
{
"name":"key",
"original":null,
"new":"fighter"
},
{
"name":"name",
"original":null,
"new":"fighter"
},
{
"name":"active",
"original":null,
"new":true
},
{
"name":"allow_game_writes",
"original":null,
"new":true
},
{
"name":"allow_api_writes",
"original":null,
"new":true
}
],
"children":[
{
"id":null,
"entity_id":{
"original":null,
"new":"01GJ34JX11FTAR4AFRDE38NFJ9"
},
"operation":"Create progression tier",
"values":[
{
"name":"step",
"original":null,
"new":1
},
{
"name":"points_threshold",
"original":null,
"new":0
}
],
"children":null
}
]
},
"mage":{
"id":"01GJ34969HM62X7DWTQ4QJXXQW",
"entity_id":{
"original":null,
"new":"01GJ34969HM62X7DWTQ0QWEXVP"
},
"operation":"Create progression",
"values":[
{
"name":"key",
"original":null,
"new":"mage"
},
{
"name":"name",
"original":null,
"new":"mage"
},
{
"name":"active",
"original":null,
"new":true
},
{
"name":"allow_game_writes",
"original":null,
"new":true
},
{
"name":"allow_api_writes",
"original":null,
"new":true
}
],
"children":[
{
"id":null,
"entity_id":{
"original":null,
"new":"01GJ34H54CVVRXHX44C4VXSBCX"
},
"operation":"Create progression tier",
"values":[
{
"name":"step",
"original":null,
"new":4
},
{
"name":"points_threshold",
"original":null,
"new":2000
}
],
"children":null
},
{
"id":null,
"entity_id":{
"original":null,
"new":"01GJ34H686XFZDFR205BPXXZHH"
},
"operation":"Create progression tier",
"values":[
{
"name":"step",
"original":null,
"new":5
},
{
"name":"points_threshold",
"original":null,
"new":3000
}
],
"children":null
},
{
"id":null,
"entity_id":{
"original":null,
"new":"01GJN2C57ZN503TNJ53T72B8BY"
},
"operation":"Create progression tier",
"values":[
{
"name":"step",
"original":null,
"new":6
},
{
"name":"points_threshold",
"original":null,
"new":4000
}
],
"children":null
},
{
"id":null,
"entity_id":{
"original":null,
"new":"01GJ34969N84J32MG8WHTBYM84"
},
"operation":"Create progression tier",
"values":[
{
"name":"step",
"original":null,
"new":1
},
{
"name":"points_threshold",
"original":null,
"new":0
}
],
"children":null
},
{
"id":null,
"entity_id":{
"original":null,
"new":"01GJ34GY6XD0NGRHXV6HHVJYM9"
},
"operation":"Create progression tier",
"values":[
{
"name":"step",
"original":null,
"new":2
},
{
"name":"points_threshold",
"original":null,
"new":400
}
],
"children":[
{
"id":null,
"entity_id":null,
"operation":"Add progression points reward",
"values":[
{
"name":"progression_name",
"original":null,
"new":"fighter"
},
{
"name":"points_amount",
"original":null,
"new":100
}
],
"children":null
},
{
"id":null,
"entity_id":null,
"operation":"Add progression reset reward",
"values":[
{
"name":"progression_name",
"original":null,
"new":"rogue"
}
],
"children":null
},
{
"id":null,
"entity_id":null,
"operation":"Add asset reward",
"values":[
{
"name":"asset_id",
"original":null,
"new":2
},
{
"name":"asset_variation_id",
"original":null,
"new":null
},
{
"name":"asset_rental_option_id",
"original":null,
"new":null
}
],
"children":null
}
]
},
{
"id":null,
"entity_id":{
"original":null,
"new":"01GJ34H31MKHQD09K12WFEEQ4A"
},
"operation":"Create progression tier",
"values":[
{
"name":"step",
"original":null,
"new":3
},
{
"name":"points_threshold",
"original":null,
"new":1000
}
],
"children":null
}
]
},
"rogue":{
"id":"01GJ34K7QBEB124MVE8F62BVNM",
"entity_id":{
"original":null,
"new":"01GJ34K7QBEB124MVE8BCFPAMG"
},
"operation":"Create progression",
"values":[
{
"name":"key",
"original":null,
"new":"rogue"
},
{
"name":"name",
"original":null,
"new":"rogue"
},
{
"name":"active",
"original":null,
"new":true
},
{
"name":"allow_game_writes",
"original":null,
"new":true
},
{
"name":"allow_api_writes",
"original":null,
"new":true
}
],
"children":[
{
"id":null,
"entity_id":{
"original":null,
"new":"01GJ34K7QDB5QNCZQKE002076N"
},
"operation":"Create progression tier",
"values":[
{
"name":"step",
"original":null,
"new":1
},
{
"name":"points_threshold",
"original":null,
"new":0
}
],
"children":null
}
]
}
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
Merge Diff
curl -X POST "https://api.lootlocker.io/admin/game/100/progressions/diff/merge" \
-d "{\"ids\": [\"01GJ34JX0VKJKM4P6X9ND3G5X2\", \"01GJ34969HM62X7DWTQ4QJXXQW\"] }" \
-H "Content-Type: application/json"
Merges the diff based on ID's sent in the body.
URL Structure
/admin/game/<game_id>/progressions/diff/merge
Example Response
This endpoint will not have a body, being a
204 No Content
HTTP response.
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
Available input fields
Field | Description |
---|---|
ids | List of Diff ID's that should be merged to live, obtained via GET /progressions/diff endpoint. |
Bones
Bones are used to let the game client know how to attach assets to characters.
Get Bones To Game
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/bones" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will return a list of bones and their parameters.
Example Response
{
"success": true,
"bones": [
{
"bone": {
"id": 50,
"name": "snowmobile_ski_left"
},
"parameters": [
{
"name": "rotation",
"value": "1,0,0,0",
"type": "string"
},
{
"name": "position",
"value": "-0.53,0.93,-0.35",
"type": "string"
},
{
"name": "boneName",
"value": "Bip01",
"type": "string"
},
{
"name": "type",
"value": "CA_BONE",
"type": "string"
}
]
}
],
"types": [
"boolean",
"string",
"number"
]
}
Update Bones
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/bones" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"bones\": [{\"bone\": {\"id\": 50, \"name\": \"snowmobile_ski_left\"}, \"parameters\": [{\"name\": \"rotation\", \"value\": \"1,0,0,0\", \"type\": \"string\"}]}]}"
When updating bones, you should send data in the same format as you get when you list bones to a game. Parameters are looked up by name on the backend, so supplying a new unique name, will create a new bone. You can set as many parameters as you want.
The response from this endpoint is the same as from Get Bones To Game.
Maps
Getting All Maps To A Game
curl -X GET "https://api.lootlocker.io/admin/v1/maps/game/{game_id}"
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will return all maps with all their spawnpoints. If you need more information about the map than is provided here, call the assets endpoint, which will contain the poster image, name and what else you might need.
Example response
{
"success": true,
"maps": [
{
"map_id": 1,
"asset_id": 938,
"spawnpoints": [
{
"guid": "{ef7e9ca1-d3c8-47be-bc6a-b9d8556cab3b}",
"id": 1,
"asset_id": 939,
"position": "123585818123",
"rotation": "19588188841",
"cameras": [
{
"position": "1495986818281823",
"rotation": "1495986818281823"
}
]
},
{
"guid": "{09ca78e6-1719-43bc-becc-2a04cae9715d}",
"id": 2,
"asset_id": 940,
"position": "868181824845",
"rotation": "868186810",
"cameras": [
{
"position": "868190040011",
"rotation": "96817767100108681"
}
]
}
]
},
{
"map_id": 2,
"asset_id": 950,
"spawnpoints": [
{
"guid": "{38070225-a4d8-4db3-a8c9-550e806c6216}",
"id": 7,
"asset_id": 951,
"position": "123585818123",
"rotation": "19588188841",
"cameras": [
{
"position": "1495986818281823",
"rotation": "1495986818281823"
}
]
},
{
"guid": "{997b0abe-706f-49e9-9925-67d2454223e2}",
"id": 8,
"asset_id": 952,
"position": "868181824845",
"rotation": "868186810",
"cameras": [
{
"position": "868190040011",
"rotation": "96817767100108681"
}
]
}
]
}
]
}
Creating Maps
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/maps"
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
-H "Content-Type: application/json"
-d "{\"json\": \"goes here\"}"
When creating a map, you send a POST request with the payload data. This will create the map, an asset for it and spawn points with their own assets for each spawn point you've sent along.
On success, this endpoint will return the full list of maps as documented in Getting All Maps To A Game.
On error you will receive a response similar to the error example shown.
Request payload example
{
"name": "Sialia",
"game_id": 2,
"spawn_points": [
{
"guid": "{997b0abe-706f-49e9-9925-67d2454223e2}",
"position": "123551231",
"rotation": "156516991",
"name": "Eastwater Forest",
"cameras": [
{
"position": "12958181",
"rotation": "9591885818"
}
]
}
]
}
Property | Description | Required |
---|---|---|
game_id | Id of the game the map should belong to | Yes |
name | Name of the map | Yes |
asset_id | The ID of an asset if you've created one and don't want this call to do it for you. | No |
spawn_points | An array of spawn point objects. See below. | No |
Spawn Points
Spawn points have a few properties.
Property | Description | Required |
---|---|---|
position | Coordinates for where the spawn point should be positioned | Yes |
rotation | Coordinates for the rotation of the spawn point | Yes |
name | Name of the spawn point | Yes |
guid | A 38-character long unique identifier provided by you | No |
cameras | An array of cameras for the spawn point. See below. | No |
Error response example
{
"success": false,
"error": "Required parameter on camera \"position\" missing."
}
Cameras
Cameras are simple as they have just 2 properties.
Property | Description | Required |
---|---|---|
position | Coordinates for where the camera should be positioned | Yes |
rotation | Coordinates for the rotation of the camera | Yes |
Updating Maps
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/maps/{map_id}"
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
-H "Content-Type: application/json"
-d "{\"json\": \"goes here\"}"
Updating maps follow the same rules as creating them, with a few exceptions. The request type is PATCH
instead of POST
and the url having the map_id
appended to it.
When updating a map, send along the id
's for the spawn points. Otherwise the backend will create new ones. Any spawn points not sent will be deleted.
Always send the cameras for a spawn point, as default behaviour is to delete all, and then re-create from the input given by the call.
Events
Creating Missions
curl -X POST "https://api.lootlocker.io/admin/v1/missions/game/{game_id}"
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
-H "Content-Type: application/json"
-d "{\"game_id\": 1, \"type\": 1, \"name\": \"Eastwater River\", \"goals\":{\"gold\": {\"goal\": \"00:20:00\", \"points\": 400, \"assets\": [{\"asset_id\": 24, \"asset_variation_id\": 43}]},\"silver\": {\"goal\": \"00:30:00\", \"points\": 200},\"bronze\": {\"goal\": \"00:35:00\", \"points\": 100}], \"checkpoints\": [{\"guid\": \"{f5bf1883-5192-4cd0-b251-8752d83c9bc2}\", \"index\": 1, \"x\": \"y\", \"foo\": \"bar\", \"baz\": \"foobar\"},{\"guid\": \"{54e54736-d290-4565-ae17-d19f90611c85}\", \"index\": 2, \"x\": \"y1\", \"foo\": \"bar1\", \"baz\": \"foobar1\"},{\"guid\": \"{ef7e9ca1-d3c8-47be-bc6a-b9d8556cab3b}\", \"index\": 3, \"x\": \"y2\", \"foo\": \"bar2\", \"baz\": \"foobar2\"}]}"
When creating a mission, you send a POST request with the payload data. This will create the mission and an asset for the mission, which you can later update with the update method.
You can set the following information:
Root level properties:
Property | Description | Required |
---|---|---|
name | A name for the mission | Yes |
game_id | The ID of the game to which this mission shall belong | Yes |
type | An integer representing the type of mission you're creating | Yes |
map_id | An integer representing the ID of the map this mission belongs to | Yes |
asset_id | A reference to an asset you've created that you want to attach this mission to, if not supplied, one will be created automatically | No |
poster_path | A string representing a path to a poster to display for this mission. | No |
rounds | An integer representing the number of rounds in the mission | No |
round_length | A string formatted as "00:00:000" for representing minutes, seconds and milliseconds | No |
completion_bonus | A point based bonus for completing the mission, represented as an integer | No |
difficulty_name | A string for representing the difficulty of the mission | No |
difficulty_multiplier | A decimal number that will be multiplied with the point_reward from the medal field and completion_bonus from the mission |
No |
time_score_multiplier | An integer that will be multiplied with the amount of seconds that a player is faster than the round_length for mission of type 3 | No |
goals | Array of objects, see Goals below |
No |
checkpoints | Array of objects, see Checkpoints below |
No |
filters | Array of objects, see Filters |
No |
Types
Three different types of missions are currently supported.
Type | Description |
---|---|
1 | Time based and calculates based on time. |
2 | Score based and calculates based on score. |
3 | Time based, but calculates based on how many seconds faster the player was than round_length, and multiplies those seconds by time_score_multiplier |
Checkpoints
Checkpoint example
[
{
"index": 1,
"your_property": "your value",
"your_second_property": "your second value"
}
]
A mission can have an unlimited amount of checkpoints. For checkpoints you can add as many properties as you want, in a key/value style. There is a required index
field which is used to set the order of the checkpoints.
Send your checkpoints in the format that you see in the example. You can send your values in any format, but they will always be treated and returned as strings.
Goals
Goals example
{
"gold": {
"goal": "5000",
"points": 400,
"assets": [
{
"asset_id": 24,
"asset_variation_id": 43
}
]
},
"silver": {
"goal": "4500",
"points": 350
},
"bronze": {
"goal": "3000",
"points": 200
}
}
You can add as many goals to a mission as you want. The object name is the name of the goal, which can be anything that'll fit in a JSON object.
Property | Description | Required |
---|---|---|
goal | A string, with either a time based goal, or points | yes |
points | An integer representing the point that will be rewarded and multiplied by the difficulty_multiplier from the mission |
yes |
assets | An array of assets that will be granted the first time the player reaches the goal, if it's the highest they've reached | no |
Filters
Filters example
[
{
"name": "Mission Type",
"value": "Freeride"
}
]
You can add as many filters to a mission as you want. Both properties are required. These will be returned with assets later.
Keep in mind that these might be used to let users filter assets at a later point, so keep them human friendly.
Property | Description |
---|---|
name | A name for your filter, such as Mission Type |
value | A value for the filter, such as Freeride |
Updating Missions
curl -X PATCH "https://api.lootlocker.io/admin/v1/missions/game/{game_id}/{mission_id}"
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
-H "Content-Type: application/json"
-d "{\"asset_id\": 6718, \"game_id\": 1, \"type\": 1, \"name\": \"Eastwater River\", \"goals\":{"gold": {\"goal\": \"00:20:00\", \"points\": 400, \"assets\": [{\"asset_id\": 24, \"asset_variation_id\": 43}]}, "silver": {\"goal\": \"00:30:00\", \"points\": 200},"bronze": {\"goal\": \"00:35:00\", \"points\": 100}], \"checkpoints\": [{\"guid\": \"{f5bf1883-5192-4cd0-b251-8752d83c9bc2}\", \"index\": 1, \"x\": \"y\", \"foo\": \"bar\", \"baz\": \"foobar\"},{\"guid\": \"{54e54736-d290-4565-ae17-d19f90611c85}\", \"index\": 2, \"x\": \"y1\", \"foo\": \"bar1\", \"baz\": \"foobar1\"},{\"guid\": \"{ef7e9ca1-d3c8-47be-bc6a-b9d8556cab3b}\", \"index\": 3, \"x\": \"y2\", \"foo\": \"bar2\", \"baz\": \"foobar2\"}]}"
Updating a mission follows the same format as creating one with the exception that any checkpoints
or goals
that you do not supply in an update will be removed. If you do not wish to change them, simply omit them in the request. Any field is optional, and only changed if a new value is supplied. Also, notice the addition of the {mission_id} to the url.
If you want to make sure the name of the mission isn't changed, you can send along a GET style parameter called protect_name
and set it to true
.
Getting All Missionss
curl -X GET "https://api.lootlocker.io/admin/v1/missions/game/{game_id}"
When working with missions, you might want to get them all. Issuing a call to this endpoint with a valid game_id
will get that for you. In the example you'll see a simple mission with 2 checkpoints, and 3 goals.
Example Response
{
"success": true,
"missions": [
{
"mission_id": 1,
"asset_id": 912,
"rounds": 0,
"round_length": "0",
"difficulty_name": null,
"difficulty_multiplier": null,
"goals": {
"gold": {
"goal": "00:20:00",
"points": "400"
},
"silver": {
"goal": "00:30:00",
"points": "200"
},
"bronze": {
"goal": "00:35:00",
"points": "100"
}
},
"checkpoints": [
{
"guid": "{54e54736-d290-4565-ae17-d19f90611c85}",
"index": 1,
"segment_time": 18510,
"your_key": "your value",
"your_second_key": "your second value"
},{
"guid": "{f5bf1883-5192-4cd0-b251-8752d83c9bc2}",
"index": 2,
"your_key": "your value",
"your_second_key": "your second value"
}
]
}
]
}
Triggers
Triggers are a simple way to have game events perform actions on the backend, such as granting assets or awarding XP.
List Triggers
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/triggers" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will list all triggers, and their rewards.
The times
property on a trigger denotes how many times this trigger can be triggered, and drop a reward to the player. Once the trigger has been triggered this number of times, any subsequent triggerings will not drop any rewards. If you wish to set a trigger to an unlimited amount of triggers, set the times
property to null
.
Example Response
{
"success": true,
"triggers": [
{
"id": 112,
"name": "enterArea.SialiaSummit",
"times": 1,
"grant_all": false,
"rewards": [
{
"trigger_reward_id": 1,
"asset_id": 0,
"asset_variation_id": null,
"asset_image": null,
"asset_name": "",
"score": 100
}
]
},
{
"id": 113,
"name": "enterArea.BluebirdRidge",
"times": 1,
"grant_all": false,
"rewards": [
{
"trigger_reward_id": 2,
"asset_id": 0,
"asset_variation_id": null,
"asset_image": null,
"asset_name": "",
"score": 100
}
]
}
]
}
Create Trigger
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/triggers" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"name\": \"enterArea.SialiaBurgerBar\", \"times\": 10, \"grant_all\": false, \"rewards\": [{\"score\": 100}]}"
Creating a trigger requires sending data about said trigger in JSON form.
The name
value is what will be called as a trigger from the Game API.
The times
field is how many times this trigger should be called before the rewards will stop being granted to the player. Set to null
for no limits.
The grant_all
field is to let the backend know if it should reward all the rewards of this trigger, or select one at random.
The rewards
field is an array of rewards. This can be either XP in the form of a score
field, or an asset, in the form of asset_id
and asset_variation_id
fields.
The response from this endpoint will be the list of triggers.
Update Trigger
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/triggers/112" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"name\": \"enterArea.SialiaSummit\", \"times\": 4, \"grant_all\": true, \"rewards\": [{\"trigger_reward_id\": 1, \"score\": 500}]}"
Updating a trigger follows the same format as creating one, with the exception that any existing rewards need to have a trigger_reward_id
. If a trigger is sent without one, it will be treated as a new reward instead of changing the existing one.
The response from this endpoint will be the list of triggers.
Delete Trigger
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}/triggers/112" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"name\": \"enterArea.SialiaSummit\", \"times\": 4, \"grant_all\": true, \"rewards\": [{\"score\": 500}]}"
This endpoint deletes a trigger, and all progress players have made towards it.
The response from this endpoint will be the list of triggers.
Leveling
List Levels
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/levels" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will list the games levels, and their rewards.
The grant_all
field references if players should be granted all assets, or just one at random when they reach a level.
The xp_threshold
field denotes how much XP is necessary to reach this level.
Example Response
{
"success": true,
"levels": [
{
"id": 8,
"level": 0,
"xp_threshold": 0,
"grant_all": false,
"grants": []
},
{
"id": 9,
"level": 1,
"xp_threshold": 1000,
"grant_all": false,
"grants": [
{
"id": 57,
"level_id": 9,
"asset_id": 1370,
"asset_variation_id": 0,
"asset_name": "100 Credits Reward",
"asset_image": null,
"grant_id": 57
}
]
}
]
}
Save Levels
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/levels" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "[{\"id\": 8, \"xp_threshold\": 1500, \"grant_all\": false}, {\"level\": 61, \"xp_threshold\": 160000, \"grant_all\": false}]"
You save levels by sending them all in an array to the API. If you supply the id
field, it will update an existing level, if you don't you will have to supply the level
property too, and it will use that to create a new level.
The response from this endpoint will be the same as from the List Levels endpoint.
Add Reward
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/levels/grant" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-d "level_id=8&asset_id=1405&asset_variation_id=1906"
To add a reward, you send a POST request with parameters identifying the level you wish to add a reward for using level_id
, the asset_id
, and asset_variation_id
.
The response from this endpoint is the same as from List Levels.
Update Reward
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/levels/grant/57" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-d "level_id=9&asset_id=1405&asset_variation_id=1906"
To update a reward, you need to provide the id of the reward in the url. Other than that, it's identical to the Add Reward call.
The response from this endpoint is the same as from List Levels.
Delete Reward
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}/levels/grant/57" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Deleting a reward is done by sending a delete request to the rewards endpoint.
The response from this endpoint is the same as from List Levels.
Collectables
Collectables are used to automatically reward players for collecting or completing something in your game. They are nested into three layers, each with their own set of rewards.
The Admin API is used for managing the collectables available to the game.
To read more about collectables in general you can read our Collectables Product Documentation.
Get Collectables
curl -X GET "https://api.lootlocker.io/admin/game/100/collectables"
Get list of collectables.
URL Structure
/admin/game/<game_id>/collectables
Example Response
{
"success": true,
"collectables": [
{
"id": 123,
"name": "Some Collectable",
"grant_all": false
},
{
"id": 1234,
"name": "Some Other Collectable",
"grant_all": true
},
{
"id": 321,
"name": "Also a collectable",
"grant_all": false
}
]
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
Get Collectable Details
curl -X GET "https://api.lootlocker.io/admin/game/100/collectables/123"
Get collectable details. This response includes the entire collectable structure, with all groups, items and rewards.
URL Structure
/admin/game/<game_id>/collectables/<collectable_id>
Example Response
{
"success": true,
"collectable": {
"live_collectable_id": 122,
"dev_collectable_id": 123,
"id": 123,
"name": "Some Collectable",
"grant_all": false,
"rewards": [
{
"id": 1,
"asset_id": 20,
"asset_variation_id": 0,
"asset_rental_option_id": 0
}
],
"groups": [
{
"id": 100,
"name": "Collectable Group",
"grant_all": false,
"rewards": [
{
"id": 80,
"asset_id": 6,
"asset_variation_id": 0,
"asset_rental_option_id": 0
}
],
"items": [
{
"id": 188,
"name": "Collectable Group Item",
"grant_all": false,
"rewards": [
{
"id": 82,
"asset_id": 8,
"asset_variation_id": 0,
"asset_rental_option_id": 0
}
]
},
{
"id": 190,
"name": "Some Other Collectable Group Item",
"grant_all": false,
"rewards": []
}
]
}
]
}
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
collectable_id | ID of the collectable |
Create Collectable
curl -X POST "https://api.lootlocker.io/admin/game/100/collectables" \
-d "{\"name\": \"Some Collectable\"}" \
-H "Content-Type: application/json"
Create a new collectable. The create endpoint only create the initial collectable, use the update endpoint to add additional data to the collectable.
URL Structure
/admin/game/<game_id>/collectables
Example Response
{
"success": true,
"collectable": {
"id": 123,
"name": "Some Collectable",
"grant_all": false
}
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
Available input fields
All fields are required.
Field | Description |
---|---|
name | Name of your collectable |
Update Collectable
curl -X PUT "https://api.lootlocker.io/admin/game/100/collectables/123" \
-d '{"live_collectable_id":61,"dev_collectable_id":62,"id":62,"name":"Some collectable test","grant_all":true,"rewards":[{"asset_id":12,"asset_variation_id":null,"asset_rental_option_id":null}],"groups":[{"name":"Collectable Group","grant_all":false,"items":[{"name":"Some Item","grant_all":false,"rewards":[{"asset_id":2,"asset_variation_id":null,"asset_rental_option_id":null}],"expanded":true},{"name":"Some Other Item","grant_all":false,"rewards":[],"expanded":false}],"rewards":[{"asset_id":6,"asset_variation_id":null,"asset_rental_option_id":null}]}]}' \
-H "Content-Type: application/json"
URL Structure
/admin/game/<game_id>/collectables/<collectable_id>
Example Response
{
"success": true,
"collectable": {
"live_collectable_id": 61,
"dev_collectable_id": 62,
"id": 62,
"name": "Some collectable test",
"grant_all": true,
"rewards": [
{
"id": 96,
"asset_id": 12,
"asset_variation_id": 0,
"asset_rental_option_id": 0
}
],
"groups": [
{
"id": 84,
"name": "Collectable Group",
"grant_all": false,
"rewards": [
{
"id": 98,
"asset_id": 6,
"asset_variation_id": 0,
"asset_rental_option_id": 0
}
],
"items": [
{
"id": 200,
"name": "Some Item",
"grant_all": false,
"rewards": [
{
"id": 100,
"asset_id": 2,
"asset_variation_id": 0,
"asset_rental_option_id": 0
}
]
},
{
"id": 202,
"name": "Some Other Item",
"grant_all": false,
"rewards": []
}
]
}
]
}
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
collectable_id | ID of the collectable |
Example Input JSON
Example Input
{
"live_collectable_id": 61,
"dev_collectable_id": 62,
"id": 62,
"name": "Some collectable test",
"grant_all": true,
"rewards": [
{
"id": 96,
"asset_id": 12,
"asset_variation_id": 0,
"asset_rental_option_id": 0
}
],
"groups": [
{
"id": 84,
"name": "Collectable Group",
"grant_all": false,
"rewards": [
{
"id": 98,
"asset_id": 6,
"asset_variation_id": 0,
"asset_rental_option_id": 0
}
],
"items": [
{
"id": 200,
"name": "Some Item",
"grant_all": false,
"rewards": [
{
"id": 100,
"asset_id": 2,
"asset_variation_id": 0,
"asset_rental_option_id": 0
}
]
},
{
"id": 202,
"name": "Some Other Item",
"grant_all": false,
"rewards": []
}
]
}
]
}
Here you can see the general structure of input for updating a collectable.
Delete Collectable
curl -X DELETE "https://api.lootlocker.io/admin/game/100/collectables/123"
Delete collectable.
URL Structure
/admin/game/<game_id>/collectables/<collectable_id>
{
"success": true
}
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
collectable_id | ID of the collectable |
DLC
Please note that DLC migrations are currently only for Steam integrations. For PSN, use consumable entitlements instead. These will be checked on game start.
List DLCs To Game
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/dlc" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will list all DLC's for a game.
The dlc_identifier
field is the app id steam provides for the DLC. These are 6 digits always.
The always_check
boolean denotes if this DLC is checked every time the game starts. The purpose of this is to allow for migratory DLC's where people have bought a game with DLCs, before the game was hooked up to the backend. If they're only checked once, the backend will only check if the player owns them with steam the first time it sees the player. If always_check
is set to true, the dlc_identifier
value will be returned with the Game API session registration for the game to check if any of the DLC's are owned. See the Game API docs for how to handle this.
Example Response
{
"success": true,
"dlcs": [
{
"id": 1,
"name": "Season Pass",
"dlc_identifier": "257300",
"always_check": false,
"active": true,
"created_at": "2015-03-01 00:00:00",
"updated_at": "2015-05-26 14:01:20",
"product_count": 6
}
]
}
Create DLC To Game
curl -X POST "https://api.lootlocker.io/admin/game/{game_id}/dlc" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"name\": \"Season Pass\"}"
To create a DLC package, you simply send a POST with a name of the package you wish to create.
Example Response
{
"success": true,
"dlc_id": 1
}
Get DLC Details
curl -X GET "https://api.lootlocker.io/admin/game/{game_id}/dlc/1" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
The DLC details endpoint will list details about a DLC package, including it's contents.
Example Response
{
"success": true,
"dlc": {
"id": 21,
"name": "Test",
"dlc_identifier": "0",
"always_check": "1",
"active": "0",
"created_at": "2016-08-19 10:43:22",
"updated_at": "2016-08-19 10:43:22",
"assets": [
{
"id": 62,
"name": "Rival Pro",
"image": "https://pm-game-files.s3.amazonaws.com/2/56f54a14b12e7.png",
"variation_id": 131,
"variation_name": "k2-13-rivalpro-green"
},
{
"id": 1380,
"name": "Source Z",
"image": "https://pm-game-files.s3.amazonaws.com/2/56f67b5c8e33a.png",
"variation_id": 1873,
"variation_name": "black"
}
]
}
}
Update DLC Details
curl -X PATCH "https://api.lootlocker.io/admin/game/{game_id}/dlc/1" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"active\": true, \"assets\": [{\"id\": 62, \"variation_id\": 131}]}"
When updating a DLC package, all fields are optional. Only the ones passed in will be changed.
If assets
is passed in, all assets not in the array will be removed. Any additional assets added will be added.
The response from this endpoint is the same as from Get DLC Details.
Messages
Messages are used to send news and promotions to your players.
Get Messages To Game
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/messages" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will return a list of messages for a game. It will include drafts (messages without a published_at
date set), and the messages will be the full messages, with all content.
The example only includes one response for brevity.
Example Response
{
"success": true,
"messages": [
{
"id": 4,
"live_player_message_id": 3,
"dev_player_message_id": null,
"title": "Message Title",
"summary": "Message Summary",
"message_body": "This is a rather lengthy body.\r\n\r\nLorem ipsum dolor sit amet, consectetur adipiscing elit. Aenean congue urna vitae venenatis mattis. Nunc volutpat finibus nisl ut imperdiet. Mauris sed orci at leo posuere tincidunt ut ut leo. In hac habitasse platea dictumst. Sed pulvinar, magna in pharetra finibus, neque nibh elementum nisl, at pulvinar mauris augue in felis. Cras accumsan nec purus in dapibus. Nullam rhoncus accumsan condimentum. Nullam consequat ipsum sit amet porttitor varius. Curabitur lacinia in tortor eget egestas.",
"category": "Levels",
"action": ":store\/levels\/new",
"alert": true,
"image_url": null,
"image_name": null,
"published_at": "2017-09-12 15:55:22",
"created_at": "2017-09-12 08:39:48",
"updated_at": "2017-09-13 08:19:18"
}
]
}
Get Message
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/messages/4" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will return a single message.
Example Response
{
"success": true,
"message": {
"id": 4,
"live_player_message_id": 3,
"dev_player_message_id": null,
"title": "Message Title",
"summary": "Message Summary",
"message_body": "This is a rather lengthy body.\r\n\r\nLorem ipsum dolor sit amet, consectetur adipiscing elit. Aenean congue urna vitae venenatis mattis. Nunc volutpat finibus nisl ut imperdiet. Mauris sed orci at leo posuere tincidunt ut ut leo. In hac habitasse platea dictumst. Sed pulvinar, magna in pharetra finibus, neque nibh elementum nisl, at pulvinar mauris augue in felis. Cras accumsan nec purus in dapibus. Nullam rhoncus accumsan condimentum. Nullam consequat ipsum sit amet porttitor varius. Curabitur lacinia in tortor eget egestas.",
"category": "Levels",
"action": ":store\/levels\/new",
"alert": true,
"image_url": null,
"image_name": null,
"published_at": "2017-09-12 15:55:22",
"created_at": "2017-09-12 08:39:48",
"updated_at": "2017-09-13 08:19:18"
}
}
Create Message
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/messages" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"title\": \"My fancy message title\"}"
Creating a message is simple. There are only one required field: title
. Everything else is optional.
The title
and summary
fields have length settings on the game settings. They have sensible defaults, but you might want to change them for your game because of UI space etc.
Example Response
{
"success": true,
"message": {
"id": 4,
"live_player_message_id": 3,
"dev_player_message_id": null,
"title": "My fancy message title",
"summary": "",
"message_body": "",
"category": "",
"action": "",
"alert": false,
"image_url": null,
"image_name": null,
"published_at": null,
"created_at": "2017-09-12 08:39:48",
"updated_at": "2017-09-13 08:19:18"
}
}
The optional fields are as follows:
Field | Type | Additional info |
---|---|---|
summary | string | This field can have a max length, set in the game settings. (Default: 140) New lines will be converted to \r\n on save. |
message_body | string | This is the body of the message. New lines will be converted to \r\n on save. |
category | string | A free text category for your message. (Max 255 characters) |
action | string | A free text string that your game can parse to perform an action on the message. (Take to store etc) |
alert | boolean | Used to let your game know if this message is an alert. |
image_url | string | This can be a string or url to any image you want to show with your message. |
image_name | string | This is only used in the admin API to help identify an image if it can't render on the platform the game is being managed from. (Eg. .dds in a browser) |
published_at | datetime | Format: 2017-09-13 12:49:33 - The date for the message to be published. |
Update Message
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/messages/4" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"title\": \"My fancier message title\", \"alert\": true}"
Updating a message functions exactly like creating one. The only difference is that the ID of the message goes in the URL and the request type is PATCH
instead of POST
. Refer to that part of the documentation for specifics.
Example Response
{
"success": true,
"message": {
"id": 4,
"live_player_message_id": 3,
"dev_player_message_id": null,
"title": "My fancier message title",
"summary": "",
"message_body": "",
"category": "",
"action": "",
"alert": true,
"image_url": null,
"image_name": null,
"published_at": null,
"created_at": "2017-09-12 08:39:48",
"updated_at": "2017-09-13 11:29:18"
}
}
Delete Message
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}/messages/4" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
The response from this endpoint will be identical to the one from Get Messages To Game.
Example Response
{
"success": true,
"messages": []
}
Files
Upload a file
curl -X POST 'https://api.lootlocker.io/admin/v1/upload' \
-H 'x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39' \
-F 'file=@path/to/your/file.bin' \
-F 'asset_id=5129' \
-F 'game_id=1234' \
-F 'visibility=private' \
-F 'tags=image;large;purpose:game_data'
This endpoint lets you upload a file and associate it with other LootLocker Game Systems, such as assets, asset instances (items) and players.
The field game_id
is required for LootLocker to be able to attach the file to a specific game.
Files can also be tagged to help your game or editor to handle them better. When adding tags to a file while uploading it, they should be in a field called tags
and be delimited with a semi-colon (;
).
If you'd like to include a purpose (a field visible in the admin), prepend a tag with purpose:
, for example purpose:save_game
.
The field visibility
is optional and can be set to public-read
or private
. If not set, the default is public-read
.
This table lists all possible Game Systems that a file can be associated with.
Example response
{
"success": true,
"url": "https://cdn.lootlocker.io/141/5f230b1e14614.txt",
"id": 13,
"size": 224,
"name": "astley-paradox.txt",
"tags": [
"image",
"large"
],
"updated_at": "2020-07-31 09:28:10"
}
Game System | Field name |
---|---|
Assets | asset_id |
Asset Instance | item_id |
Player | player_id |
Get files
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/files?filter=asset" \
-H 'x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39'
Listing files can be done by issuing a call to this endpoint. See the example response for the structure. tags
will be null
if there are no tags.
attachment_type
and attachment_id
reference which Game System a file is attached to, holding the name in the type field and the id of said system resource in the id field. Eg attachment_type = asset
and attachment_id = 1234
meaning that the file is attached to an asset
with id 1234
.
When listing files you can also filter them by attachment_type
, to only get files matching the specified filter returned. Currently the following exists:
Attachment Type | Filter Value |
---|---|
Assets | asset |
Asset Instance | item |
Player | player |
Example Response
{
"success": true,
"files": [
{
"url": "https://cdn.lootlocker.io/141/5f230b1e14614.txt",
"id": 13,
"attachment_type": "asset",
"attachment_id": 1234,
"size": 224,
"name": "astley-paradox.txt",
"tags": [
"image",
"large"
],
"updated_at": "2020-07-31 09:28:10"
}
]
}
Update file
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/files/{file_id}" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-d "{\"tags\": [\"never\", \"gonna\", \"give\", \"you\", \"up\"]}"
Updating files lets you change your tags. Send them as an array of strings in an object with a key tags
.
Example Response
{
"success": true,
"file": {
"url": "https://cdn.lootlocker.io/141/5f230b1e14614.txt",
"id": 13,
"attachment_type": "asset",
"attachment_id": 1234,
"size": 224,
"name": "astley-paradox.txt",
"tags": [
"never",
"gonna",
"give",
"you",
"up"
],
"updated_at": "2020-07-31 09:28:10"
}
}
Delete file
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}/files/{file_id}" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Deleting files can be done by issuing a call to this endpoint. Do note that files will be stored in LootLocker as long as there is a reference to them from the live game, so even though the reference is gone immediately, the actual file will not be removed until the change is merged to the live game.
Example response
{
"success": true
}
Data Entities
LootLocker supports custom data blobs that can be attached to a number of Game Systems. We call them Data Entities.
Create Data Entity
curl -X POST "https://api.lootlocker.io/admin/v1/game/{game_id}/data" \
-H "Content-Type: application/json" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-d "{\"name\": \"My custom data\", \"asset_id\": 1234, \"data\": \"your data here\"}"
When creating a Data Entity there are 2 required fields: data
and a field to tie the Data Entity to a Game System, such as asset_id
, used in the example here.
You can also assign a name to make it easier to identify the entity later. This name will not be returned through the Game API.
Example Response
{
"success": true,
"data_entity": {
"id": 1234,
"name": "My custom data",
"data": "your data here",
"updated_at": "2020-08-04 13:54:56"
}
}
The below list shows which Game Systems we currently support, and what field name to use to attach to that system.
Game System | Field |
---|---|
Assets | asset_id |
Player | player_id |
Trigger | trigger_id |
Event (Mission) Goal | event_goal_id |
Listing Data Entities
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/data/{type}/{type_id}" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Listing Data Entities are done based on which Game System they are attached to, and is referred to in the url as type
and type_id
. The below table lists the types used and what id
to use.
Example response
{
"success": true,
"data_entities": [
{
"id": 1234,
"name": "My custom data",
"data": "your data here",
"updated_at": "2020-08-04 13:54:56"
}
]
}
Game System | Type | ID |
---|---|---|
Assets | asset | Asset ID |
Player | player | Player ID |
Trigger | trigger | Trigger ID |
Event (Mission) Goal | eventgoal | Event Goal ID |
Get a single Data Entity
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/data/{data_entity_id}" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Getting a single Data Entity is done by the ID of the entity.
Example response
{
"success": true,
"data_entity": {
"id": 1234,
"name": "My custom data",
"data": "your data here",
"updated_at": "2020-08-04 13:54:56"
}
}
Update a Data Entity
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/data/{data_entity_id}" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"name\": \"My changed name\"}"
Updating a Data Entity is done by it's ID, as a PATCH
request sending the fields to update along in a JSON payload.
The following fields can be updated: name
, data
.
Example response
{
"success": true,
"data_entity": {
"id": 1234,
"name": "My changed name",
"data": "your data here",
"updated_at": "2020-08-04 14:24:35"
}
}
Delete a Data Entity
curl -X DELETE "https://api.lootlocker.io/admin/v1/game/{game_id}/data/{data_entity_id}" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Deleting a Data Entity is done by it's ID, as a DELETE
request, having the ID in the URL.
Example response
{
"success": true
}
Game Versions
Game Versions are primarily used for handling different versions of assets, in the capacity that they will not be sent to games with an lower version.
Getting Game Versions
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/version" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will list all versions that your game has.
Notice the string
property at the end, which is handy for display purposes.
Example Output
{
"success": true,
"versions": [
{
"id": "2",
"live_game_version_id": null,
"game_id": "2",
"major": "0",
"minor": "5",
"revision": "1",
"build": "569095",
"created_at": "2015-03-27 16:22:51",
"updated_at": "2015-03-27 16:22:51",
"deleted_at": null,
"string": "0.5.1.569095"
},
{
"id": "3",
"live_game_version_id": null,
"game_id": "2",
"major": "0",
"minor": "5",
"revision": "2",
"build": "571294",
"created_at": "2015-03-30 15:06:43",
"updated_at": "2015-03-30 15:06:43",
"deleted_at": null,
"string": "0.5.2.571294"
}
]
}
Getting Game Versions to a Dev Game
curl -X GET "https://api.lootlocker.io/admin/v1/game/{game_id}/version/develop" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
In addition to using the above endpoint with the ID of a development version of a game, you can call this utility endpoint and get the same response, but for the games development version.
Feature Toggles and Settings
List Configured Feature Toggles and Settings
curl -X GET "https://api.lootlocker.io/admin/v1/game/1/features" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint lets you list all configured feature toggles and settings your game has.
Example Response
{
"success": true,
"feature_toggles": [
{
"feature": "ugc",
"enabled": true,
"toggled_at": "2020-12-11 15:17:32",
"toggled_by": 2,
"settings": {
"player_max_entries": 6,
"moderation_enabled": false
}
}
]
}
Get Feature Toggles and Settings by Name
curl -X GET "https://api.lootlocker.io/admin/v1/game/1/feature/ugc" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint lets you get a specific feature toggle with it's settings. Useful for enabling features in your UI.
Example Response
{
"success": true,
"is_enabled": true,
"settings": {
"player_max_entries": 6,
"moderation_enabled": false
}
}
Set Feature Toggles and Settings
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/1/feature" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "json payload here"
This endpoint lets you change the feature toggles and settings for your game. Use the table here to know what features can be toggled, and what settings they can have.
We have omitted the JSON payload in the example call as each feature have quite different payload options.
Disable Game API Endpoints
Disable Game API Endpoints Example Payload
{
"feature": "disable_game_api_endpoints",
"enabled": true,
"settings": {
"endpoints": [
"GET_/game/v1/messages"
]
}
}
This toggle allows you to disable any endpoint in the Game API so that requests will be rejected with a 403 Forbidden
error code, and the error message "Endpoint disabled in Game API".
Setting | Type | Default | Description |
---|---|---|---|
endpoints | array | empty | An array of strings formatted with a concatenated version of the HTTP Verb and URL of the endpoint, eg: GET_/game/v1/messages . |
User Generated Content
User Generated Content is a feature that can be completely turned off using the toggle. It also has the following settings.
User Generated Content Example Payload
{
"feature": "ugc",
"enabled": true,
"settings": {
"moderation_enabled": true
}
}
Setting | Type | Default | Description |
---|---|---|---|
moderation_enabled | boolean | false | If set to false, UGC content will automatically be promoted to Assets once they are marked as done. If true, a moderation queue will be created. |
Default Character Creation
By default the default character class is created for a player when they are seen the first time. To disable this functionality, set the auto_create
toggle to false for the default_character
feature.
Default Character Creation Example Payload
{
"feature": "default_character",
"enabled": true,
"settings": {
"auto_create": false
}
}
Setting | Type | Default | Description |
---|---|---|---|
auto_create | boolean | true | If set to false, LootLocker will stop automatically creating a character when a new player is seen for the first time. |
Character Loadouts
Setting | Type | Default | Description |
---|---|---|---|
only_one_per_context | boolean | true | If true , only one asset instance per context can be equipped at the same time. |
item_limit | integer | 6 | Limits the number of asset instances that can be equipped per context. Will be ignored if only_one_per_context is set to true . |
Character Inventories Example Payload
{
"feature": "character_inventories",
"enabled": true,
"settings": {
"only_one_per_context": true,
"item_limit": 6
}
}
Character Inventories
Setting | Type | Default | Description |
---|---|---|---|
grant_to_default_character | boolean | false | If enabled, granted assets will also be scoped to the players default character. |
Character Inventories Example Payload
{
"feature": "character_inventories",
"enabled": true,
"settings": {
"grant_to_default_character": true
}
}
Heroes
Setting | Type | Default | Description |
---|---|---|---|
unique_player_heroes | boolean | true | If enabled, players can only have one instance of a specific hero at a time. |
Heroes Example Payload
{
"feature": "heroes",
"enabled": true,
"settings": {
"unique_player_heroes": false
}
}
Unique Character Types
Setting | Type | Default | Description |
---|---|---|---|
unique_character_types | boolean | false | If enabled, players can only have one instance of a specific character type at a time. |
Unique Character Types Example Payload
{
"feature": "character",
"enabled": true,
"settings": {
"unique_character_types": true
}
}
Inventories
Setting | Type | Default | Description |
---|---|---|---|
remove_global_on_unequip | boolean | false | If enabled, asset instances that were granted to the player while they were global will be removed from their inventories when unequipped. This setting affects Heroes, Characters and Players. |
Inventories Example Payload
{
"feature": "inventories",
"enabled": true,
"settings": {
"remove_global_on_unequip": true
}
}
Organisations
Get Users To An Organisation
curl -X GET "https://api.lootlocker.io/admin/v1/organisation/1/users" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This call will get you all users belonging to a specific organisation, if the user you're acting as has access to the organisation.
Invite A User To An Organisation
curl -X POST "https://api.lootlocker.io/admin/v1/organisation/1/users" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"name\": \"Andreas Stokholm\", \"email\": \"andreas@lootlocker.io\"}"
This endpoint can be called to invite existing users to an organisation or create new users who will automatically be part of the organisation they're being invited to. This is agnostic to the API and is automatically handled.
Once this endpoint has been called, the user will receive an email, telling them that either an account have been created for them, or that they've been added to a new organisation.
Example Response
{
"success": true
}
Get User To An Organisation
curl -X GET "https://api.lootlocker.io/admin/v1/organisation/1/users/1" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
The response from this endpoint will be details about the user.
Example Response
{
"success": true,
"user": {
"id": 1,
"name": "Andreas Stokholm",
"email": "andreas@lootlocker.io",
"uses_2fa": false,
"last_login": null
}
}
Remove Two-Factor Authentication For A User
curl -X DELETE "https://api.lootlocker.io/admin/v1/organisation/1/users/1/2fa" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Requesting this endpoint will remove Two-Factor Authentication from the user. They will get an email notifying them about it.
Example Response
{
"success": true
}
Reset Password For A User
curl -X DELETE "https://api.lootlocker.io/admin/v1/organisation/1/users/1/password" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Requesting this endpoint will initiate the process of resetting the users password. This means they will get an email with a link to reset the password, just like if they requested it themselves at login.
Example Response
{
"success": true
}
Users
Set Up Two-Factor Authentication
curl -X POST "https://api.lootlocker.io/admin/v1/user/2fa" \
-H "x-auth-token: 4b711a8a40b678fbc9afdb2fc0a1492530002de8"
This endpoint will initiate the process of setting up Two-Factor Authentication. The response will have to be presented to the user, for them to set up their device.
The mfa_token_url
is a base64 encoded png of a QR code the user can scan with their device.
Example QR Code:
Example Response
{
"success": true,
"mfa_token_url": ""
}
Verify Two-Factor Authentication Setup
curl -X PATCH "https://api.lootlocker.io/admin/v1/user/2fa" \
-H "x-auth-token: 4b711a8a40b678fbc9afdb2fc0a1492530002de8" \
-H "Content-Type: application/json" \
-d "{\"secret\": 2552663}"
To finalize the Two-Factor Authentication, the user have to provide the secret from their device, which will result in a recovery token being returned.
Example Response
{
"success": true,
"recover_token": "117248:951659:058195:576195"
}
Remove Two-Factor Authentication
curl -X DELETE "https://api.lootlocker.io/admin/v1/user/2fa" \
-H "x-auth-token: 4b711a8a40b678fbc9afdb2fc0a1492530002de8" \
-d "secret=123456"
To remove Two-Factor Authentication from the currently logged in user, send a DELETE
request to this endpoint, supplied an Two-Factor Authentication token with it.
Example Response
{
"success": true
}
Example Error Response
{
"success": false,
"error": "The provided Multi Factor Authentication token was invalid."
}
Update User Details
curl -X PATCH "https://api.lootlocker.io/admin/user" \
-H "x-auth-token: 4b711a8a40b678fbc9afdb2fc0a1492530002de8" \
-H "Content-Type: application/json" \
-d "{\"name\": \"Loot Lockster\"}"
You can update certain information on a user by patching it this endpoint.
Field | Type | Value |
---|---|---|
name | string | The updated user's name |
Example Response
{
"success": true,
"user": {
"name": "Loot Lockster",
"email": "loot@lootlocker.com",
"verified_at": "2023-03-06T14:05:39Z"
}
}
Platforms
Update Platforms
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/platforms" \
-H "Content-Type: application/json" \
-d "{\"platforms\": [{\"id\": 1, \"name\": \"steam\", \"enabled\": true, \"properties\": {\"steam_app_id\": \"1234567\"}}]}"
This endpoint will allow you to enable and disable platforms, as well as setting the properties for each of them. The valid platforms and their properties are listed in the tables below. All properties are string types.
Example Response
{
"success": true,
"platforms": [
{
"id": 1,
"name": "steam",
"friendly_name": "steam",
"properties": {
"steam_app_id": "1234567",
"trade_restriction_days": "3",
"publisher_key": "ABCDEFGHIJKLMNOPQRSTUVWXYZ012345",
"asset_server_key": "abcdefghijklmnopqrstuvwxyz012345"
},
"enabled": true
},
{
"id": 2,
"name": "psn",
"friendly_name": "playstation network",
"properties": {
"client_id": "",
"client_secret": "",
"service_label": {
"1": {
"region_id": 1,
"region": "Europe",
"value": ""
},
"2": {
"region_id": 2,
"region": "America",
"value": ""
}
}
},
"enabled": false
},
{
"id": 3,
"name": "roblox",
"friendly_name": null,
"properties": null,
"enabled": false
},
{
"id": 4,
"name": "apple_app_store",
"friendly_name": "ios",
"properties": {
"app_shared_secret": ""
},
"enabled": false
},
{
"id": 5,
"name": "google_play_store",
"friendly_name": "android",
"properties": {
"service_account": "",
"package_name": ""
},
"enabled": false
},
{
"id": 6,
"name": "good_old_games",
"friendly_name": "gog",
"properties": null,
"enabled": false
},
{
"id": 7,
"name": "epic_store",
"friendly_name": "epic store",
"properties": null,
"enabled": false
},
{
"id": 8,
"name": "xbox",
"friendly_name": "xbox",
"properties": null,
"enabled": false
},
{
"id": 9,
"name": "nintendo_switch",
"friendly_name": "nintendo switch",
"properties": null,
"enabled": false
}
]
}
Steam
Name parameter: steam
ID parameter: 1
Property Key | Property Value Example |
---|---|
steam_app_id | 1234567 |
trade_restriction_days | 3 |
publisher_key | ABCDEFGHIJKLMNOPQRSTUVWXYZ012345 |
asset_server_key | abcdefghijklmnopqrstuvwxyz012345 |
If you want to change the asset_server_key
, set the value to rotate
and it will be rotated for you, with the new key returned in the response.
PSN
Name parameter: psn
ID parameter: 2
Property Key | Property Value Example |
---|---|
client_id | 1234567 |
client_secret | 3 |
service_label | ABCDEFGHIJKLMNOPQRSTUVWXYZ012345 |
service_label.N.value | abcdefghijklmnopqrstuvwxyz012345 |
Google Play Store
Name parameter: google_play_store
ID parameter: 5
Property Key | Property Value Example |
---|---|
service_account | long json object |
package_name | My Game |
Apple App Store
Name parameter: apple_app_store
ID parameter: 4
Property Key | Property Value Example |
---|---|
app_shared_secret | abcdefghijklmnopqrstuvwxyz012345 |
Roblox
Name parameter: roblox
ID parameter: 3
Not yet supported. The toggle functions as a signal to LootLocker that the platform should be prioritized.
XBox
Name parameter: xbox
ID parameter: 8
Not yet supported. The toggle functions as a signal to LootLocker that the platform should be prioritized.
Good Old Games
Name parameter: good_old_games
ID parameter: 6
Not yet supported. The toggle functions as a signal to LootLocker that the platform should be prioritized.
Epic Store
Name parameter: epic_store
ID parameter: 7
Not yet supported. The toggle functions as a signal to LootLocker that the platform should be prioritized.
Nintendo Switch
Name parameter: nintendo_switch
ID parameter: 9
Not yet supported. The toggle functions as a signal to LootLocker that the platform should be prioritized.
List Platforms
curl -X PATCH "https://api.lootlocker.io/admin/v1/game/{game_id}/platforms"
This endpoint will return all platforms, and their current configuration state. See the above Update Platforms for explanation of properties.
Example Response
{
"success": true,
"platforms": [
{
"id": 1,
"name": "steam",
"friendly_name": "steam",
"properties": {
"steam_app_id": "1234567",
"trade_restriction_days": "3",
"publisher_key": "ABCDEFGHIJKLMNOPQRSTUVWXYZ012345",
"asset_server_key": "abcdefghijklmnopqrstuvwxyz012345"
},
"enabled": true
},
{
"id": 2,
"name": "psn",
"friendly_name": "playstation network",
"properties": {
"client_id": "",
"client_secret": "",
"service_label": {
"1": {
"region_id": 1,
"region": "Europe",
"value": ""
},
"2": {
"region_id": 2,
"region": "America",
"value": ""
}
}
},
"enabled": false
},
{
"id": 3,
"name": "roblox",
"friendly_name": null,
"properties": null,
"enabled": false
},
{
"id": 4,
"name": "apple_app_store",
"friendly_name": "ios",
"properties": {
"app_shared_secret": ""
},
"enabled": false
},
{
"id": 5,
"name": "google_play_store",
"friendly_name": "android",
"properties": {
"service_account": "",
"package_name": ""
},
"enabled": false
},
{
"id": 6,
"name": "good_old_games",
"friendly_name": "gog",
"properties": null,
"enabled": false
},
{
"id": 7,
"name": "epic_store",
"friendly_name": "epic store",
"properties": null,
"enabled": false
},
{
"id": 8,
"name": "xbox",
"friendly_name": "xbox",
"properties": null,
"enabled": false
},
{
"id": 9,
"name": "nintendo_switch",
"friendly_name": "nintendo switch",
"properties": null,
"enabled": false
}
]
}
White Label Login
Delete White Label Login User
curl -X DELETE "https://api.lootlocker.io/admin/game/1/whitelabel/user/123"
This deletes a White Label Login user from the system.
NOTE: This does not delete any player data in your game, only the user in the White Label Login system.
We also remove any sessions the user might have in the White Label Login System.
URL Structure
/admin/game/<game_id>/whitelabel/user/<player_id>
Example Response
This endpoint will return 204 No Content on success
URL Parts
Part | Description |
---|---|
game_id | ID of the game |
player_id | ID of the player in LootLocker |
Currency
Create New Currency
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/currency' \
--header 'x-auth-token: {auth_token}' \
--header 'Content-Type: application/json' \
--data '{
"name": "Wood",
"code": "WOO",
"game_id": 23647,
"initial_denomination_name": "Log"
}'
{
"created_at": "2023-10-10T16:02:52Z",
"id": "01HCD57AK0Y2NEJS17E0P1ZK0Z",
"name": "Wood",
"code": "woo",
"game_id": 23647,
"game_api_writes_enabled": false
}
This endpoint creates a new currency for the game.
HTTP Request
POST https://api.lootlocker.io/admin/game/{game_id}/currency
Parameters
Parameter | Type | Description | Example | Notes |
---|---|---|---|---|
name | string | The name of the currency | Wood | |
code | string | The code of the currency | WOO | Exactly 3 characters, per ISO 4217 |
game_id | number | The id of the game | 23647 | |
initial_denomination_name | string | The name of the initial denomination | Log |
Create New Denomination For Currency
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/currency/{currency_id}/denominations' \
--header 'x-auth-token: {auth_token}' \
--header 'Content-Type: application/json' \
--data '{
"name": "some denomination",
"value": 10
}'
Response
{
"created_at": "2023-10-10T16:22:32Z",
"id": "01HCD6BAQEP60E9GNXG2TS1P4Q",
"currency": "01GQHF38EWBC2H70MF3JBRHQ7J",
"name": "some denomination",
"value": 10
}
HTTP Request
POST https://api.lootlocker.io/admin/game/{game_id}/currency/{currency_id}/denominations
Parameters
Parameter | Type | Description | Example |
---|---|---|---|
currency_id | number | The id of the currency | 01HCB096VGSAQBTJAGS1X9B4RG |
Enable Game API Writes
curl --location --request PATCH 'https://api.lootlocker.io/admin/game/{game_id}/currency/{currency_id}/enable-game-writes' \
--header 'x-auth-token: {auth_token}' \
Response
{
"success": true
}
HTTP Request
PATCH https://api.lootlocker.io/admin/game/{game_id}/currency/{currency_id}/enable-game-writes
Parameters
Parameter | Type | Description | Example |
---|---|---|---|
currency_id | number | The id of the currency | 01HCB096VGSAQBTJAGS1X9B4RG |
Disable Game API Writes
curl --location --request PATCH 'https://api.lootlocker.io/admin/game/{game_id}/currency/{currency_id}/disable-game-writes' \
--header 'x-auth-token: {auth_token}'
Response
{
"success": true
}
HTTP Request
PATCH https://api.lootlocker.io/admin/game/{game_id}/currency/{currency_id}/disable-game-writes
Parameters
Parameter | Type | Description | Example |
---|---|---|---|
currency_id | number | The id of the currency | 01HCB096VGSAQBTJAGS1X9B4RG |
Delete Currency
curl --location --request DELETE 'https://api.lootlocker.io/admin/game/{game_id}/currency/{currency_id}' \
--header 'x-auth-token: {auth_token}'
Response
{
"message": "currency deleted",
"success": true
}
HTTP Request
DELETE https://api.lootlocker.io/admin/game/{game_id}/currency/{currency_id}
Parameters
Parameter | Type | Description | Example |
---|---|---|---|
currency_id | number | The id of the currency | 01HCB096VGSAQBTJAGS1X9B4RG |
Delete Denomination
curl --location --request DELETE 'https://api.lootlocker.io/admin/game/{game_id}/denominations/{denomination_id}' \
--header 'x-auth-token: {auth_token}'
Response
{
"message": "denomination deleted",
"success": true
}
HTTP Request
DELETE https://api.lootlocker.io/admin/denominations/{denomination_id}
Parameters
Parameter | Type | Description | Example |
---|---|---|---|
denomination_id | number | The id of the denomination | 01HCB096VGSAQBTJAGS1X9B4RG |
Get Currency By Game & Code
Parameter | Type | Description | Example |
---|---|---|---|
game_id | number | The id of the game | 123 |
currency_code | string | The code of the currency | 01HCAZM4B3P3KPQ6S80RM57RKQ |
curl --location 'https://api.lootlocker.io/admin/currency/game/{game_id}/code/{currency_code}' \
--header 'x-auth-token: {auth_token}' \
Get Dependents For Currency
Parameter | Type | Description | Example |
---|---|---|---|
currency_id | number | The id of the currency | 01HCB096VGSAQBTJAGS1X9B4RG |
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/currency/{currency_id}/dependents' \
--header 'x-auth-token: {auth_token}'
List Currencies By Game
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/currencies/game/{game_id}' \
--header 'x-auth-token: {auth_token}'
Response
{
"currencies": [
{
"created_at": "2023-10-10T16:02:52Z",
"id": "01HCD57AK0Y2NEJS17E0P1ZK0Z",
"name": "Wood",
"code": "woo",
"game_id": 23647,
"game_api_writes_enabled": true
}
]
}
HTTP Request
GET https://api.lootlocker.io/admin/game/{game_id}/currencies/game/{game_id}
Parameters
Parameter | Type | Description | Example |
---|---|---|---|
game_id | number | The id of the game | 123 |
List Denominations By Currency
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/currency/{currency_id}/denominations' \
--header 'x-auth-token: {auth_token}'
Response
{
"denominations": [
{
"created_at": "2023-10-10T16:22:32Z",
"id": "01HCD6BAQEP60E9GNXG2TS1P4Q",
"currency": "01GQHF38EWBC2H70MF3JBRHQ7J",
"name": "some denomination",
"value": 10
}
]
}
HTTP Request
GET https://api.lootlocker.io/admin/game/{game_id}/currency/{currency_id}/denominations
Parameters
Parameter | Type | Description | Example |
---|---|---|---|
currency_id | number | The id of the currency | 01HCB096VGSAQBTJAGS1X9B4RG |
Balances
Create Wallet
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/wallet' \
--header 'x-auth-token: {auth_token}' \
--header 'Content-Type: application/json' \
--data '{
"holder_id": "01HAPTTKA2B9KG1PSF12HDS4G4",
"holder_type": "player"
}'
Response
{
"wallet_id": "01HCEZ12V17PPP8QKZ4PG20KJJ"
}
HTTP Request
POST /admin/wallet
Parameters
Parameter | Type | Description |
---|---|---|
holder_id | string | ID of the holder |
holder_type | string | Type of the holder (player or character) |
List Balances
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/balances/wallet/{wallet_id}' \
--header 'x-auth-token: {auth_token}'
Response
{
"balances": [
{
"created_at": "2023-05-10T09:27:00Z",
"amount": "4184768942",
"holder_type": "player",
"currency": {
"code": "woo",
"name": "Wood",
"id": "01H00MTAPTE4VRPRZJZMT5RTBH"
},
"holder_id": 2422917
}
]
}
HTTP Request
GET /admin/balances/wallet/{wallet_id}
Parameters
Parameter | Type | Description |
---|---|---|
wallet_id | string | ID of the wallet |
Credit Balance
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/balances/credit' \
--header 'x-auth-token: {auth_token}' \
--header 'Content-Type: application/json' \
--data '{
"amount": "1000",
"wallet_id": "01H52M0RVAWP8AD5WE2JB3KTS9",
"currency_id": "01H4NR864V9J4YJ90A6ATA85Z8"
}'
Response
{
"balance": {
"amount": "1000",
"created_at": "2023-05-09T16:17:14Z",
"currency_id": "01H00MTAPTE4VRPRZJZMT5RTBH",
"holder_id": 123,
"holder_type": "player"
}
}
HTTP Request
POST /admin/balances/credit
Parameters
Parameter | Type | Description |
---|---|---|
amount | string | Amount to credit, in minor currency units (smallest increment) |
wallet_id | string | ID of the wallet |
currency_id | string | ID of the currency |
Debit Balance
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/balances/debit' \
--header 'x-auth-token: {auth_token}' \
--header 'Content-Type: application/json' \
--data '{
"amount": "100",
"wallet_id": "01H52M0RVAWP8AD5WE2JB3KTS9",
"currency_id": "01H4NR864V9J4YJ90A6ATA85Z8"
}'
Response
{
"balance": {
"amount": "900",
"created_at": "2023-05-10T09:27:00Z",
"currency_id": "01H00MTAPTE4VRPRZJZMT5RTBH",
"holder_id": 2422917,
"holder_type": "player"
}
}
Insufficient funds
{
"message": "Insufficient funds for from player 2422917: held amount: 900, requested debit: 1000",
"request_id": "132e392b-5a75-4ecb-99b4-e30610d1a8fe",
"trace_id": "7c55f99f086390a7731a8430233cb158"
}
HTTP Request
POST /admin/balances/debit
Parameters
Parameter | Type | Description |
---|---|---|
amount | string | Amount to debit, in minor currency units (smallest increment) |
wallet_id | string | ID of the wallet |
currency_id | string | ID of the currency |
Get Wallet
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/wallet/{wallet_id}' \
--header 'x-auth-token: {auth_token}'
Response
{
"holder_id": "01HCCQS1H0217TSM8QXQXKQVXS",
"id": "01HCCQZS8DQR1VFK73W9K6P29X",
"type": "player"
}
Use this request if you have a wallet and want to find additional details about it.
HTTP Request
GET /admin/wallets/{wallet_id}
Parameters
Parameter | Type | Description |
---|---|---|
wallet_id | string | ID of the wallet |
Get Wallet for Holder
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/wallet/holder/{holder_id}' \
--header 'x-auth-token: {auth_token}'
Response
{
"holder_id": "01HCCQS1H0217TSM8QXQXKQVXS",
"id": "01HCCQZS8DQR1VFK73W9K6P29X",
"type": "player"
}
Use this request if you have a holder and want to find additional details about its wallet.
HTTP Request
GET /admin/wallet/holder/{holder_id}
Parameters
Parameter | Type | Description |
---|---|---|
holder_id | string | ID of the holder |
Catalogs
Create Catalog
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/catalog' \
--header 'x-auth-token: {auth_token}' \
--header 'Content-Type: application/json' \
--data '{
"name": "crafting",
"key": "crafting",
"game_id": 30129
}'
Response
{
"created_at": "2023-10-11T11:05:21Z",
"name": "crafting",
"key": "crafting",
"game_id": 30129,
"id": "01HCF6K8DG12KTY98A9P2MDF0X"
}
Create a new catalog for your game.
Note that the key must be unique for your game.
HTTP Request
POST https://api.lootlocker.io/admin/game/{game_id}/catalog
Parameters
Parameter | Type | Description |
---|---|---|
game_id | integer | Required. The id of the game you want to create the catalog for. |
name | string | Required. The name of the catalog. |
key | string | Required. The key of the catalog. |
Delete Catalog
curl --location --request DELETE 'https://api.lootlocker.io/admin/game/{game_id}/catalog/{catalog_id}' \
--header 'x-auth-token: {auth_token}'
Response
{
"message": "catalog deleted",
"success": true
}
HTTP Request
DELETE https://api.lootlocker.io/admin/game/{game_id}/catalog/{catalog_id}
Parameters
Parameter | Type | Description |
---|---|---|
catalog_id | string | Required. The id of the catalog you want to delete. |
List Catalogs For Game
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/catalog/{catalog_id}' \
--header 'x-auth-token: {auth_token}'
Response
{
"catalogs": [
{
"created_at": "2023-10-11T09:47:55Z",
"name": "Some Catalog",
"key": "some_catalog",
"game_id": 23647,
"id": "01HCF25FGQDM09MYWA6YBN8AX6",
"deleted_at": null
}
]
}
HTTP Request
GET https://api.lootlocker.io/admin/game/{game_id}/catalogs/
Parameters
Parameter | Type | Description |
---|---|---|
game_id | integer | Required. The id of the game you want to retrieve the catalogs for. |
List Catalog Items
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/catalog/{catalog_id}/prices?cursor={next_cursor}&per_page={per_page}' \
--header 'x-auth-token: auth_token'
Response
{
"catalog": {
"id": "01HCF25FGQDM09MYWA6YBN8AX6",
"name": "Some Catalog",
"key": "some_catalog"
},
"entries": [
{
"created_at": "2023-10-11T11:19:35Z",
"entity_kind": "asset",
"entity_name": "Sword",
"prices": [
{
"amount": "100",
"display_amount": "100 WOO",
"currency_code": "woo",
"currency_name": "Wood",
"price_id": "01HCF7DAZX31BS757PCB5P5H1X",
"currency_id": "01HCD57AK0Y2NEJS17E0P1ZK0Z"
}
],
"entity_id": "01HAM2XM04TMAGAYA8KTKT6QTE",
"catalog_listing_id": "01HCF7DAZYBXTS70H9SABJF604",
"purchasable": false
}
],
"assets_details": [
{
"name": "Sword",
"variation_id": null,
"rental_option_id": null,
"legacy_id": 298778,
"id": "01HAM2XM04TMAGAYA8KTKT6QTE",
"catalog_listing_id": "01HCF7DAZYBXTS70H9SABJF604",
"thumbnail": null
}
],
"progression_points_details": [],
"progression_resets_details": [],
"currency_details": [],
"pagination": {
"previous_cursor": null,
"next_cursor": "01HCF7DAZRG74V2T3F7KZJ2KVN",
"total": 2
}
}
HTTP Request
GET https://api.lootlocker.io/admin/game/{game_id}/catalog/{catalog_id}/prices
URL Parameters
Parameter | Type | Description |
---|---|---|
catalog_id | string | Required. The id of the catalog you want to retrieve the items for. |
Query Parameters
Parameter | Type | Description |
---|---|---|
cursor | string | Optional. The cursor to use for pagination. |
per_page | integer | Optional. The amount of items to retrieve per page. Defaults to 10. |
Update Catalog Name
curl --location --request PUT 'https://api.lootlocker.io/admin/game/{game_id}/catalog/{catalog_id}' \
--header 'x-auth-token: {auth_token}' \
--header 'Content-Type: application/json' \
--data '{
"id": "01HCF25FGQDM09MYWA6YBN8AX6",
"name": "Online Store 3"
}'
Response
{
"name": "Online Store 3",
"key": "some_catalog",
"id": "01HCF25FGQDM09MYWA6YBN8AX6"
}
Update the name of a catalog.
Note: The key of a catalog cannot be changed.
HTTP Request
PUT https://api.lootlocker.io/admin/game/{game_id}/catalog/{catalog_id}
Parameters
Parameter | Type | Description |
---|---|---|
catalog_id | string | Required. The id of the catalog you want to update. |
name | string | Required. The new name of the catalog. |
Create A Price For An Asset
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/catalog/price' \
--header 'x-auth-token: dac49695d7ceff25f91a19e24c3d8a5c30c01a8c' \
--header 'Content-Type: application/json' \
--data '{
"game_id": 23647,
"catalog_id": "01HCF25FGQDM09MYWA6YBN8AX6",
"entity_id": "",
"entity_kind": "asset",
"currency_id": "01HCD57AK0Y2NEJS17E0P1ZK0Z",
"amount": "1000"
}'
Asset Variation
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/catalog/price' \
--header 'x-auth-token: dac49695d7ceff25f91a19e24c3d8a5c30c01a8c' \
--header 'Content-Type: application/json' \
--data '{
"game_id": 23651,
"catalog_id": "01HCHS8HC409BJ25F7F3FA83DA",
"entity_id": "01HCHYNNP1ZNCJMDJZYNARPQY1",
"entity_kind": "asset",
"currency_id": "01HBDGJAV5X82FZSKCGN7RD0KK",
"amount": "123",
"metadata": [
{
"key": "asset_variation_id",
"value": "6"
}
]
}'
Rental Assets
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/catalog/price' \
--header 'x-auth-token: dac49695d7ceff25f91a19e24c3d8a5c30c01a8c' \
--header 'Content-Type: application/json' \
--data '{
"game_id": 23651,
"catalog_id": "01HCHS8HC409BJ25F7F3FA83DA",
"entity_id": "01HCHYPNPWW8RC33HBV68WQ5JP",
"entity_kind": "asset",
"currency_id": "01HBDGJAV5X82FZSKCGN7RD0KK",
"amount": "123",
"metadata": [
{
"key": "asset_rental_option_id",
"value": "2"
}
]
}'
Optional Field
"catalog_listing_id": "{catalog_listing_id}"
Response
{
"amount": "1000",
"kind": "asset",
"id": "01GV1D4N8F0QKSMHMT8K4V6J3A",
"catalog_id": "01GV0YGM96AJS0WVTHGW9QXQPP",
"reward_id": "01GV1D4N8CX5RR88P1ZWJD7912",
"currency_id": "01GTEJHZJMCMVGHYP9KQP6F7EF",
"purchasable": false
}
Those two prices will require two separate requests, one for each currency.
In order to group these two prices into a single listing, you will need to provide the optional "catalog_listing_id"
field
in any subsequent requests for the same listing.
The value of this field should be the value of the "id"
field returned in
the response of the first request.
HTTP Request
POST https://api.lootlocker.io/admin/game/{game_id}/catalog/price
Parameters
Parameter | Type | Description |
---|---|---|
game_id | integer | Required. The id of the game you want to create the price for. |
catalog_id | string | Required. The id of the catalog you want to create the price for. |
entity_id | string | Required. The id of the entity you want to create the price for. |
entity_kind | string | Required. The kind of entity you want to create the price for. Can be asset , currency , progression_points , progression_reset . |
currency_id | string | Required. The id of the currency you want to create the price for. |
amount | string | Required. The amount of the price. |
catalog_listing_id | string | Optional. The id of the catalog listing you want to add the price to. This is used to group multiple prices into a single listing. |
Create A Price For Progression Points
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/catalog/price' \
--header 'x-auth-token: {auth_token}' \
--header 'Content-Type: application/json' \
--data '{
"game_id": 30129,
"catalog_id": "01H52F71WJZA6XA2YN9NK0P1KQ",
"entity_id": "01H52F4NQ42R8NSNNSB08RQH3P",
"entity_kind": "progression_points",
"currency_id": "01H4NR864V9J4YJ90A6ATA85Z8",
"amount": "619",
"metadata": [
{
"key": "progression_points_amount",
"value": "1000"
}
]
}'
Response
{
"amount": "123",
"kind": "progression_points",
"id": "01HCVR51EY4NPMBPG7BQ82Q5VG",
"catalog_id": "01HCVR415T7MXMQHE4JP8KFK1D",
"reward_id": "01HCVR51ETMY26Z159FGYWCFB4",
"currency_id": "01HCVR4JQS4S58B73Q19GSA6ZK",
"catalog_item_id": "01HCVR51F03ESCWGP0MR6KKRBD"
}
HTTP Request
POST https://api.lootlocker.io/admin/game/{game_id}/catalog/price
Parameters
Parameter | Type | Description |
---|---|---|
game_id | integer | Required. The id of the game you want to create the price for. |
catalog_id | string | Required. The id of the catalog you want to create the price for. |
entity_id | string | Required. The id of the entity you want to create the price for. |
entity_kind | string | Required. The kind of entity you want to create the price for. Can be asset , currency , progression_points , progression_reset . |
currency_id | string | Required. The id of the currency you want to create the price for. |
amount | string | Required. The amount of the price. |
metadata | array | Required. The metadata of the price. This should contain a single key-value pair with the key being progression_points_amount and the value being the amount of progression points the player will receive when purchasing this price. |
Create A Price For Progression Resets
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/catalog/price' \
--header 'x-auth-token: {auth_token}' \
--header 'Content-Type: application/json' \
--data '{
"game_id": 30129,
"catalog_id": "01HCVRBQ39MD16Z30FEXHPAGN9",
"entity_id": "01HCVRC0K17KEBSAPX55ZBX8PE",
"entity_kind": "progression_reset",
"currency_id": "01HCVRCBA8CMZ18JX0274SAHJ2",
"amount": "480"
}'
Response
{
"amount": "480",
"kind": "progression_reset",
"id": "01HCVRDG3YEXBRZBJ77ENH08AF",
"catalog_id": "01HCVR415T7MXMQHE4JP8KFK1D",
"reward_id": "01HCVRDG3FGECFKG9EQ7A89NEX",
"currency_id": "01HCVR4JQS4S58B73Q19GSA6ZK",
"catalog_item_id": "01HCVRDG3Z271VNE26419TN1W6"
}
HTTP Request
POST https://api.lootlocker.io/admin/game/{game_id}/catalog/price
Parameters
Parameter | Type | Description |
---|---|---|
game_id | integer | Required. The id of the game you want to create the price for. |
catalog_id | string | Required. The id of the catalog you want to create the price for. |
entity_id | string | Required. The id of the entity you want to create the price for. |
entity_kind | string | Required. The kind of entity you want to create the price for. Can be asset , currency , progression_points , progression_reset . |
currency_id | string | Required. The id of the currency you want to create the price for. |
amount | string | Required. The amount of the price. |
Create A Price For A Currency
curl --location 'https://api.lootlocker.io/admin/game/{game_id}/catalog/price' \
--header 'x-auth-token: {auth_token}' \
--header 'Content-Type: application/json' \
--data '{
"game_id": 30129,
"catalog_id": 01HCVRBQ39MD16Z30FEXHPAGN9,
"entity_id": "01HCVRHK56F9Z1CBM7XJ2YS18F",
"entity_kind": "currency",
"currency_id": "01GV5C24KGJ3706MX02PJVQX3F",
"amount": "453",
"metadata": [
{
"key": "purchased_amount",
"value": "100000"
}
]
}'
Response
{
"amount": "480",
"kind": "currency",
"id": "01HCVRDG3YEXBRZBJ77ENH08AF",
"catalog_id": "01HCVR415T7MXMQHE4JP8KFK1D",
"reward_id": "01HCVRDG3FGECFKG9EQ7A89NEX",
"currency_id": "01HCVR4JQS4S58B73Q19GSA6ZK",
"catalog_item_id": "01HCVRDG3Z271VNE26419TN1W6"
}
HTTP Request
POST https://api.lootlocker.io/admin/game/{game_id}/catalog/price
Parameters
Parameter | Type | Description |
---|---|---|
game_id | integer | Required. The id of the game you want to create the price for. |
catalog_id | string | Required. The id of the catalog you want to create the price for. |
entity_id | string | Required. The id of the entity you want to create the price for. |
entity_kind | string | Required. The kind of entity you want to create the price for. Can be asset , currency , progression_points , progression_reset . |
currency_id | string | Required. The id of the currency you want to create the price for. |
amount | string | Required. The amount of the price. |
metadata | array | Required. The metadata of the price. This should contain a single key-value pair with the key being purchased_amount and the value being the amount of currency the player will receive when purchasing this price. |
Player Operations
In some cases, operations made by a player are recorded by the server.
Those actions can then be reviewed in the Console, or queried using the API.
Get Player Operations
curl --location 'https://api.lootlocker.io/admin/playerops/player/{player_ulid}?limit=100' \
--header 'x-auth-token: {auth_token}'
Response
{
"operations": [
{
"created_at": "2023-10-16T08:17:21.96879Z",
"event_code": "balance_credit",
"human_description": "Balance credited",
"metadata": [
{
"key": "amount",
"val": "123"
},
{
"key": "currency",
"val": "gld"
},
{
"key": "wallet_id",
"val": "01HCVRYVHHXMYSE88DVXMRNKX5"
},
{
"key": "player_id",
"val": "01HCHRKVX4W7KSBN7HMYDM3BQQ"
},
{
"key": "source",
"val": "admin_api"
},
{
"key": "action_perfomed_by_user",
"val": "10197"
}
],
"player_id": "01HCHRKVX4W7KSBN7HMYDM3BQQ",
"game_id": 23647,
"id": "01HCVRZ8HFFR77FDVEYCPV96T3"
}
]
}
HTTP Request
GET https://api.lootlocker.io/admin/playerops/player/{player_ulid}?limit=100
URL Parameters
Parameter | Type | Description |
---|---|---|
player_ulid | string | Required. The ULID of the player. |
limit | integer | Optional. The maximum number of operations to return. Defaults to 100. |
LootLocker Subscriptions
These subscriptions are for subscribing your games to LootLocker plans, and getting the status of a games subscription status.
Get Subscription Status
curl -X GET "https://api.lootlocker.io/admin/subscriptions/:game_id" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
Example response for a subscribed game
{
"plan": "Pro",
"cadence": "yearly",
"usage": 117002,
"subscription_billing_date": "2024-05-05T00:00:00+02:00",
"usage_billing_date": "2023-07-05T00:00:00+02:00",
"included_mau": 10000,
"expiring": false
}
The subscription_billing_date
is the date that the next subscription payment will be taken. The usage_billing_date
is the date that the next usage payment will be taken. The usage
in the response is the total number of monthly active users for the game, and resets at the start of each month. The included_mau
is the number of monthly active users that are included in the plan.
The expiring
property will be true if the subscription is set to expire at the end of the current billing cycle.
Example response for a game that isn't subscribed
{
"plan": "Free",
"cadence": "",
"usage": 0,
"subscription_billing_date": "0001-01-01T00:00:00Z",
"usage_billing_date": "2023-07-05T00:00:00+02:00",
"included_mau": 1000,
"expiring": false
}
Subscribe to a Plan
curl -X POST "https://api.lootlocker.io/admin/subscriptions/:game_id" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39" \
-H "Content-Type: application/json" \
-d "{\"plan\": \"pro-monthly\"}"
This endpoint will allow you to subscribe a game to a plan. The response will contain a link to Stripe which you should redirect the user to, for them to complete the checkout. Once done they will be redirected to the configured success or cancel url, depending on how the checkout went on Stripes side.
The valid plans are as follows:
Name | Cacence | Plan parameter |
---|---|---|
Hobby | N/A | hobby |
Plus | Monthly | plus-monthly |
Plus | Yearly | plus-yearly |
Pro | Monthly | pro-monthly |
Pro | Yearly | pro-yearly |
Example response
{
"checkout_url": "https://checkout.stripe.com/c/pay/...."
}
Example response for a game that is already subscribed
{
"error": "Bad Request",
"message": "game is already subscribed",
"request_id": "04b61ae5-e3b4-4b0c-a982-82b8a158a6a9",
"trace_id": "70cade8f2976785e3d53ff8f4c55756a"
}
Unsubscribe from a Plan
curl -X DELETE "https://api.lootlocker.io/admin/subscriptions/:game_id" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint can be used to cancel a games subscription to LootLocker. This will cause the subscription to expire at the end of the current billing period, at which point the game will be billed for the remaining usage on the account.
The endpoint returns a 204 No Content
response if the game was successfully unsubscribed.
Example failure response
{
"error": "Bad Request",
"message": "game is not subscribed",
"request_id": "04b61ae5-e3b4-4b0c-a982-82b8a158a6a9",
"trace_id": "70cade8f2976785e3d53ff8f4c55756a"
}
Manage a Subscription
curl -X GET "https://api.lootlocker.io/admin/subscriptions/:game_id/external-manage" \
-H "x-auth-token: 778e544ecb28ebf74cbe37855c92c5b4108fad39"
This endpoint will give you a link to an authorized session with Stripe which the user can use to manage their subscription. This is useful if they want to change their payment method, or cancel their subscription. You should not call this endpoint until the users initiates the action to start a Stripe management session. After the session has been generated, a URL will be returned that you should redirect the user to.
Example response
{
"url": "https://manage.stripe.com/..."
}
Example response for a game that is not subscribed
{
"error": "Bad Request",
"message": "game is not subscribed",
"request_id": "04b61ae5-e3b4-4b0c-a982-82b8a158a6a9",
"trace_id": "70cade8f2976785e3d53ff8f4c55756a"
}
Errors
Errors are hinted with HTTP Status codes. 200 is OK, the rest that we're using is listed below here. You should be able to handle all of these in your integration.
Error Code | Meaning |
---|---|
400 | Bad Request -- Your request has an error |
403 | Forbidden -- You are not authorised |
404 | Not Found |
405 | Method Not Allowed |
409 | Conflict -- Your state is most likely not aligned with the servers. |
500 | Internal Server Error -- We had a problem with our server. Try again later. |
503 | Service Unavailable -- We're temporarily offline for maintenance. Please try again later. |