LittleBigRefresh Documentation Help

AutoDiscover API Documentation

Rationale

To verify if a URL points to a custom server and if it is working, Refresher will contact the server.

While this API originated from Refresh, it is intended to be used by any custom server using HTTP.

The AutoDiscover API has two main purposes:

  1. Verify that the URL the user has given in patching software is correct.

  2. Provide extra information on how the patcher should work, and show metadata about the server to the user.

  3. Reassure the user that the settings they have chosen are correct.

Example

Here's an example request to the AutoDiscover API:

GET /autodiscover HTTP/1.1 Host: localhost:10061 User-Agent: curl/8.3.0 Accept: */* HTTP/1.1 200 OK Content-Type: application/json Content-Length: 287 Server: Bunkum Connection: close Date: Thu, 12 Oct 2023 00:47:58 GMT {"version":3,"serverBrand":"LBR Dev (Refresh)","serverDescription":"The primary development instance for Refresh.","url":"https://lbp.littlebigrefresh.com/lbp","bannerImageUrl":"https://github.com/LittleBigRefresh/Branding/blob/main/logos/refresh_type.png?raw=true","usesCustomDigestKey":true}

The server MUST reply with JSON data.

The client can also specify a titleId in the request:

GET /autodiscover?titleId=NPUA80662 HTTP/1.1

If the server wants to, it can change the output of the url parameter based on the given titleId. For example a LBP3 client may require HTTPS, but other clients may not be able to connect via HTTPS. In this case you would want to change to a http(s) URL for those clients.

Parameters

version refers to the schema version of the AutoDiscover API. This is not a server version.

Version 1

serverBrand: A friendly name of the server. For Refresh, it is simply Refresh, but you can put anything you want here. Generally it's the same as lbpEnvVer for LBP.

url: The URL that should be recommended to the client. This is the URL that you or your players will be patching and connecting with.

Version 2

This version is the same as version 1, with the following addition:

usesCustomDigestKey: A boolean, when true it represents that the LBP server will only accept the digest key CustomServerDigest. Otherwise, the server is using the default digest key.

Version 3

This version is the same as version 2, with the following additions:

serverDescription: An optional friendly description of the server. You can put anything you like here. Not nullable, but will be empty by default.

bannerImageUrl: An optional image that the client may retrieve. You can put any URL here as long as the link points to an image, however PNG is recommended. Can be null.

Implementations

So far, there are only a few known implementations of AutoDiscover.

  • Bunkum.AutoDiscover, a service for Bunkum to implement the protocol.

  • Refresh (via Bunkum.AutoDiscover)

  • SoundShapesServer (via Bunkum.AutoDiscover)

Last modified: 05 September 2024