Getting started

                // You'll find cURL examples, HTTP response examples,
// and other notes in this column.
                
            

The LobFile API will allow you (or an application you're writing) to automate the management of your files and other account features. The examples provided on the right column will be cURL.

To use this API, you need an API Key. Access to the API is free to anyone, no matter what account tier you have. Your API key can be found on the my-account page once you have created an account and logged in. Be sure to verify your account's Email address, otherwise requests will fail with an unauthorised error.

If you find this service useful, or if you need more performance out of LobFile (like faster downloads or more account space), please consider becoming a Patreon member.


rate limits

                // HTTP response header example, no response body.
HTTP/1.1 429 Too Many Requests
                
            

LobFile is configured with a global rate limit of 4 requests per second per IP. If you exceed this rate limit you will receive a HTTP1.1 429 Too Many Requests response with no response body.

Please be respectful with your use of the API in your integration and use case.


api requests

// Example of valid API request.
curl \
-H 'X-API-Key: ExampleAPIKey' \
-H 'Content-Type: application/json' \
-d '{"file":"5l1D"}' \
https://lobfile.com/api/v3/rest/toggle-favorite
            

The only API endpoint that requires POST form data in the request is UPLOAD. All other API endpoints require you to send JSON requests. Be sure to use the examples as an additional guide.


api responses

// Example of successful API request response.
HTTP/1.1 200 OK
{
    "success": true,
    "url": "https://lobfile.com/file/5l1D.png"
}

// Example of a failed API request response.
HTTP/1.1 401 Unauthorized
{
    "success": false,
    "error": "Invalid API key"
}

// Example of a failed API request response, no response body.
HTTP/1.1 500 Internal Server Error
            

Foremost: All HTTP requests will respond with the most relevant HTTP status code. A response with HTTP1.1 200 OK means the request was fully successful, and that the JSON response from the server will be valid.

API responses are JSON objects. Note that the server will not always be able to provide a valid JSON response. You must plan for cases where the API response may not include a valid JSON object or a JSON object at all.

All responses that contain any valid JSON will include a "success" boolean field. In some cases, an "error" JSON field will be present if there was a problem. Otherwise, you can expect whatever else is documented for that API endpoint.


authentication

// Example of X-API-Key HTTP header authentication:
curl \
-H 'X-API-Key: ExampleAPIKey' \
-F 'file=@/path/to/file.ext' \
-X POST \
https://lobfile.com/api/v3/upload.php

// Example of unauthorised response.
HTTP/1.1 401 Unauthorized
{
    "success": false,
    "error": "Invalid API key"
}
            

All HTTP requests will require you to provide an API Key for authentication. This can be done by sending a HTTP Header: X-API-Key: ExampleAPIKey with your request.

Requests that have failed authentication will yield a HTTP 401 Unauthorized response.



UPLOAD

// Example of uploading a file:
curl \
-H 'X-API-Key: ExampleAPIKey' \
-F 'file=@/path/to/file.ext' \
-X POST \
https://lobfile.com/api/v3/upload.php

// Response
HTTP/1.1 200 OK
{
    "success": true,
    "url": "https://lobfile.com/file/5l1D.png"
}

// Example of uploading a file with the optional sha_256 param:
curl \
-H 'X-API-Key: ExampleAPIKey' \
-F 'file=@/path/to/file.ext' \
-F 'sha_256=64characterhashgoeshere' \
-X POST \
https://lobfile.com/api/v3/upload.php

// Response
HTTP/1.1 500 Internal Server Error
{
    "success": false,
    "error": "Failed to get hash of file"
}
            

Endpoint: https://lobfile.com/api/v3/upload
Request Method: POST
Request Parameter Type: HTTP FORM DATA
Purpose: Upload a file to LobFile.
Notes: Upload limitations such as file size, file count, etc. will depend on your account tier, login to LobFile and visit the my-account page to see your specific account limits.

Currently, all file extensions are allowed, however certain extensions are restricted and will automatically be changed upon upload. Duplicate uploads will simply return the existing link for your account. One file per HTTP request.

POST QUERY PARAMETERS

Field Type Description
file multipart/form-data The file contents you want to upload.
sha_256 String (optional) Verifies that the file the server stored matches your provided SHA-256 hash.

RESPONSE JSON

Field Type Description
success Bool Request result
url String Full URL to the newly uploaded file.
error String (on error) A short message to indicate what went wrong.

GET-FILE-LIST

// Example retrieving the account file list:
curl \
-H 'X-API-Key: ExampleAPIKey' \
-X GET \
https://lobfile.com/api/v3/rest/get-file-list
            

Endpoint: https://lobfile.com/api/v3/rest/get-file-list
Request Method: GET
Request Parameter Type: NONE
Purpose: Retrieve the complete list of files for the account associated with the API key provided.
Note: If you are currently logged in to LobFile on this browser, you can click the link above and visit the endpoint to see the output directly (without having to provide the X-API-Key header).

QUERY PARAMETERS

Field Type Description
None

RESPONSE JSON

Field Type Description
success Bool Request result
error String (on error) A short message to indicate what went wrong.
preferred_domain String The domain to be used for building links to files (https://preferred_domain/file/name).
show_file_extensions Bool If the account is configured to include the file extension in returned links.
file_list[n][name] String The unique file name/ID of this file.
file_list[n][extension] String The file extension of this file.
file_list[n][size] Integer The file size in bytes.
file_list[n][hits] Integer Number of downloads this file has.
file_list[n][sha256] String The SHA256 of this file.
file_list[n][is_favorite] Bool Whether the file is marked as a favorite or not.
file_list[n][time_added] String When the file was uploaded.
file_list[n][last_accessed] String When the file was most recently downloaded.

TOGGLE-FAVORITE

// Example of toggling a file as a 'favorite'.
curl \
-H 'X-API-Key: ExampleAPIKey' \
-H 'Content-Type: application/json' \
-d '{"file":"5l1D"}' \
-X POST \
https://lobfile.com/api/v3/rest/toggle-favorite
            

Endpoint: https://lobfile.com/api/v3/rest/toggle-favorite
Request Method: POST
Request Parameter Type: JSON
Purpose: Mark a specific file as a "favorite".
Note: Files marked as a "Favorite" are excluded from automatic deletion by the "Continuous Uploading" account setting and appear in file-management with a gold star. This endpoint is an implicit toggle operation, rather than an explicit adjustment. The response will also indicate the new "favorite" state of the file.

JSON QUERY PARAMETERS

Field Type Description
file String The file to toggle importance on (do not include file extension, just the unique name).

RESPONSE JSON

Field Type Description
success Bool Request result
error String (on error) A short message to indicate what went wrong.
file String The file name/id that was adjusted.
is_favorite Bool The new 'favorite' state of the file.

DELETE-FILES

// Example of deleting a single file.
curl \
-H 'X-API-Key: ExampleAPIKey' \
-H 'Content-Type: application/json' \
-d '["5l1D"]' \
-X DELETE \
https://lobfile.com/api/v3/rest/delete-files

// Example of deleting multiple files at once.
curl \
-H 'X-API-Key: ExampleAPIKey' \
-H 'Content-Type: application/json' \
-d '["PduRkgR8","9qspq67Q"]' \
-X DELETE \
https://lobfile.com/api/v3/rest/delete-files            

Endpoint: https://lobfile.com/api/v3/rest/delete-files
Request Method: DELETE
Request Parameter Type: JSON
Purpose: Delete a file from the account.
Note: Files deleted from a LobFile account immediately become unavailable for download.

JSON QUERY PARAMETERS

Field Type Description
N/A List A JSON encoded list of files to delete. See the example!

RESPONSE JSON

Field Type Description
success Bool Request result
affected_files List A list of files that were successfully deleted..

GET-ACCOUNT-INFO

// Example of fetching account info.
curl \
-H 'X-API-Key: ExampleAPIKey' \
https://lobfile.com/api/v3/rest/get-account-info
            

Endpoint: https://lobfile.com/api/v3/rest/get-account-info
Request Method: GET
Request Parameter Type: NONE
Purpose: Retrieve account information.
Note: If you are currently logged in to LobFile on this browser, you can click the link above and visit the endpoint to see the output directly (without having to provide the X-API-Key header).

QUERY PARAMETERS

Field Type Description
None

RESPONSE JSON

Field Type Description
success Bool Request result
account_info[email] String Associated account's Email address as stored.
account_info[level] String Associated account's current level (as per data from Patreon).
account_info[level_upgradable] Bool Whether this account can be upgraded to a larger tier on Patreon.
account_info[api_key] String The account's API key (you probably used this as part of the request).
account_info[time_created] String The date and time that the account was created (UTC).
account_limits[space_quota] Integer The maximum allowed size of the associated account in bytes.
account_limits[slots_quota] Integer The maximum number of active files allowed at once.
account_limits[max_file_size] Integer The maximum allowed file size (of a single file).
account_limits[max_file_download_speed] Integer The max download speed (in megabits per second) of files on the associated account.
account_usage[space_used] Integer The amount of space the associated account is in bytes.
account_usage[slots_used] Integer The number of active files.

GET-ACCOUNT-SETTINGS

// Example of fetching account info.
curl \
-H 'X-API-Key: ExampleAPIKey' \
https://lobfile.com/api/v3/rest/get-account-settings
            

Endpoint: https://lobfile.com/api/v3/rest/get-account-settings
Request Method: GET
Request Parameter Type: NONE
Purpose: Retrieve account settings.
Note: If you are currently logged in to LobFile on this browser, you can click the link above and visit the endpoint to see the output directly (without having to provide the X-API-Key header).

QUERY PARAMETERS

Field Type Description
None

RESPONSE JSON

Field Type Description
success Bool Request result
account_settings[preferred_domain_value] String The domain to be used to build links ("Default Link Domain").
account_settings[return_file_extension_value] Bool If the account is configured to include the file extension in URLs ("Include Extensions").
account_settings[continuous_uploading_value] Bool If the account is configured to delete the oldest files to make room for the newest files, excluding all favorite files ("Continuous uploading").
account_settings[preferred_filename_length_value] Integer The configured desired filename length ("Filename Length").
account_settings[inactivity_auto_delete_days_value] Integer Automatically delete files that haven't been accessed in x number of days, excluding all favorite files. ("Auto Delete Inactive Files").
is_patreon_member Bool Is the account a Patreon member?