NAV
PHP cURL

General informations

Introduction

Welcome to the Alldebrid API v4 ! You can use this API to access various Alldebrid services from custom applications or scripts.

Our API is organized around REST, returns JSON-encoded responses and use standard HTTP response codes.

All calls are to be made on the HTTPS endpoints. Some are public, others require to be authentificated with an apikey (see Authentication).

This API version is namespaced as v4, as such all endpoint start with /v4/ or /v4.X/, such like http://api.alldebrid.com/v4/ping or http://api.alldebrid.com/v4.1/ping.

This API v4 should be the final version regarding general response format and errors (hopefully).

If you have any issue or question, feel free to contact us.

Response format

<?php
$ch = curl_init('https://api.alldebrid.com/v4/ping');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl "http://api.alldebrid.com/v4/ping"

The above request returns JSON structured like this :

{
    "status": "success",
    "data": {
        "ping": "pong"
    }
}
<?php
$ch = curl_init('https://api.alldebrid.com/v4/endpointDontExist');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl "http://api.alldebrid.com/v4/endpointDontExist"

The above request returns JSON structured like this :

{
    "status": "error",
    "error": {
        "code": "404",
        "message": "Endpoint doesn't exist"
    }
}

All responses return JSON with 2 attributes. The status attribute is always returned, and has a value of either success or error.

If the response is valid, you will get "status" : "success" and a data attribute, containing the response data.

If the request is invalid or an error occured, you will get "status" : "error" and an error attribute, containing the error details. All error codes and messages can be found in the errors section.

If a request doesn't return valid JSON or JSON without a status attribute, you can consider that this request failed.

This API also use HTTP status code to signal how a request went through. Codes in the 2xx range indicate success. Codes in the 4xx range indicate an error that failed given the information provided (e.g., a required parameter was omitted, a linkunlocking, etc.). Codes in the 5xx range indicate an error with Alldebrid's servers (these are rare).

HTTP Status Description
200 - OK
404 - Not Found Api endpoint doesn't exist
429 - Too Many Requests Too many requests hit the API too quickly, see Rate limiting
500, 502, 503, 504 - Server Errors Something went wrong on Alldebrid's end

Authentication

<?php
$ch = curl_init('https://api.alldebrid.com/v4/ping');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl "http://api.alldebrid.com/v4/ping"

The above request returns JSON structured like this :

{
    "status": "success",
    "data": {
        "ping": "pong"
    }
}
<?php
$ch = curl_init('https://api.alldebrid.com/v4/user'); // Authentificated endpoint with no apikey
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);

curl "http://api.alldebrid.com/v4/user"

The above request returns JSON structured like this :

{
    "status": "error",
    "error": {
        "code": "AUTH_MISSING_APIKEY",
        "message": "The auth apikey was not sent"
    }
}
<?php
$ch = curl_init('https://api.alldebrid.com/v4/user');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" "http://api.alldebrid.com/v4/ping" 

The above request returns JSON structured like this :

{
    "status": "success",
    "data": {
        "user": {
            // (...)
        }
    }
}

The Alldebrid API uses API keys to authenticate requests. You can view and manage your API keys in your Apikey dashboard, or generate them remotely (with user action) through the PIN flow.

You must send the apikey either in an Authorization: Bearer YourApikeyHere header.

All endpoints need a valid apikey except for a few public endpoints that are documented as such.

The following errors can be returned if your authentication fails.

Code Description
AUTH_MISSING_APIKEY The auth apikey was not sent
AUTH_BAD_APIKEY The auth apikey is invalid
AUTH_BLOCKED This apikey is geo-blocked or ip-blocked
AUTH_USER_BANNED This account is banned

Rate limiting

There is rate limiting in place for the API.

Current limits are at 12 requests per second and 600 requests per minute.

Any request in excess of those limits will return a 429 or 503 errors.

If you intend to make more requests than those limits, please consider throttling or grouped calls.

All endpoints

GET Public Requests

https://api.alldebrid.com/v4/ping

https://api.alldebrid.com/v4.1/pin/get

https://api.alldebrid.com/v4/hosts

https://api.alldebrid.com/v4/hosts/domains

https://api.alldebrid.com/v4/hosts/priority

GET Requests

https://api.alldebrid.com/v4/user

https://api.alldebrid.com/v4/user/hosts

https://api.alldebrid.com/v4/user/links

https://api.alldebrid.com/v4/user/history

POST Requests

https://api.alldebrid.com/v4/pin/check

https://api.alldebrid.com/v4/user/verif

https://api.alldebrid.com/v4/user/verif/resend

https://api.alldebrid.com/v4/user/notification/clear

https://api.alldebrid.com/v4/link/infos

https://api.alldebrid.com/v4/link/redirector

https://api.alldebrid.com/v4/link/unlock

https://api.alldebrid.com/v4/link/streaming

https://api.alldebrid.com/v4/link/delayed

https://api.alldebrid.com/v4/magnet/upload

https://api.alldebrid.com/v4/magnet/upload/file

https://api.alldebrid.com/v4.1/magnet/status

https://api.alldebrid.com/v4/magnet/files

https://api.alldebrid.com/v4/magnet/delete

https://api.alldebrid.com/v4/magnet/restart

https://api.alldebrid.com/v4/user/links/save

https://api.alldebrid.com/v4/user/links/delete

https://api.alldebrid.com/v4/user/history/delete

Recent modifications

Check the Changelog for a complete list.

15/01/2025

17/10/2024

16/10/2024

Pin auth

You can authenticate users in your application by using a PIN-auth flow. The steps are :

  1. Get a pin code and display it to the user

  2. The user submits the pin code on the Alldebrid pin page

  3. Once submitted, the auth apikey will be available on the api

Get pin

<?php

$ch = curl_init('https://api.alldebrid.com/v4.1/pin/get');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$response = curl_exec($ch);
$pinInfo = json_decode($response, true);

curl_close($ch);
curl "https://api.alldebrid.com/v4.1/pin/get"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "pin": "ABCD",
        "check": "664c3ca2635c99f291d28e11ea18e154750bd21a",
        "expires_in": 600,
        "user_url": "https:\/\/alldebrid.com\/pin\/?pin=ABCD",
        "base_url": "https:\/\/alldebrid.com\/pin\/",
    }
}

HTTP Request

GET https://api.alldebrid.com/v4.1/pin/get

Response attributes

Key Type Description
pin String Pin code to display to your user
check String Check token needed for the pin/check endpoint
expires_in Integer Number of second before the code expire
user_url String Url to display with PIN included
base_url String Base url

Check the pin status

<?php

// Full flow in action

$ch = curl_init('https://api.alldebrid.com/v4/pin/get');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$response = curl_exec($ch);
$pinInfo = json_decode($response, true);

curl_close($ch);

do {
    $ch = curl_init('https://api.alldebrid.com/v4/pin/check');

    curl_setopt($ch, CURLOPT_POST, true);
    curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
        'pin' => $pinInfo['pin'],
        'check' => $pinInfo['check']
    ]));
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

    $response = curl_exec($ch);
    $pinCheck = json_decode($response, true);
    curl_close($ch);

    if ($pinCheck['status'] == 'error') 
        die("Either PIN has expired or check endpoint is invalid, check errorCode");

    sleep(5);
} while ($pinCheck['data']['activated'] == false);

$authApikey = $pinCheck['data']['apikey'];

This check endpoint returns JSON structured like this if the PIN hasn't been submitted yet :

{
    "status": "success",
    "data": {
        "activated": false,
        "expires_in": 581
    }
}

Once the PIN has been submitted, the endpoin returns JSON structured like this if the PIN hasn't been submitted yet :

{
    "status": "success",
    "data": {
        "apikey": "abcdefABCDEF12345678",
        "activated": true,
        "expires_in": 570
    }
}

HTTP Request

The endpoint where the auth apikey will be available after the user submitted the PIN code on the Alldebrid website. The endpoint is available for 10 minutes after the PIN code is generated.

You should pool on the endpoint until the user has submitted the PIN code and an auth apikey is returned, or until the endpoint expires after 600 seconds.

POST https://api.alldebrid.com/v4/pin/check

Post parameters

Parameter Required Type Description
check true string Check ID from /pin/get
pin true string Pin code from /pin/get

Response attributes

Key | Always returned | Type | Description --------- | ---- | ----------- activated | Yes | Boolean | false if user didn't enter the pin on website yet expires_in | Yes | Integer | Seconds left before PIN expires apikey | No | String | Auth apikey, available once user has submitted the pin code.

Endpoint errors

Code Description
PIN_EXPIRED The pin has expired
PIN_INVALID This endpoint check parameter is invalid

Hosts

Use these endpoints to get a list of all the hosts we support, and the services of redirection (adf.ly, bit.ly) or protection we can extract links from.

If you want a live list of hosts the user can actually use depending on its subscription status, please use the authentificated /user/host endpoint.

Please consider caching the result of these calls for a few hours.

Supported hosts

<?php
$ch = curl_init('https://api.alldebrid.com/v4/hosts');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl "https://api.alldebrid.com/v4/hosts"

The above request returns JSON structured like this :

{
    "status": "success",
    "data": {
        "hosts": {
            "mega": {
                "name": "mega",
                "type": "premium",
                "domains": ["mega.nz", "mega.co.nz"],
                "regexp": "(mega(\\.co)?\\.com\/#!([0-9a-zA-Z_]{20,36}))",
                "status": true
            }
        },
        "streams": {
            "twitch": {
                "name": "twitch",
                "type": "free",
                "domains": [
                    "twitch.tv",
                    "player.twitch.tv",
                    "m.twitch.tv",
                    "go.twitch.tv",
                    "clips.twitch.tv"
                ],
                "regexp": "(https?:\/\/(?:(?:www|go|m)\\.)?twitch\\.tv\/[^\/]+\/b\/(?P<id>\\d+))|(https?:\/\/(?:(?:www|go|m)\\.)?twitch\\.tv\/(?P<id>[^\/]+)\/videos\/highlights)",
            },
        },
        "redirectors": {
            "dlprotect": {
                "name": "dlprotect",
                "type": "premium",
                "domains": [
                    "dl-protect1.com",
                    "dl-protect1.co"
                ],
                "regexp": "((dl-protect1.com\/[0-9a-z]+))|((dl\\-protect1\\.co\/go\/[0-9a-zA-Z_\\-]+))|((dl\\-protect\\.net\/[0-9a-z]+))"
            }
        }
    }
}

Use this endpoint to retrieve informations about what hosts we support and all related informations about it.

HTTP Request

GET https://api.alldebrid.com/v4/hosts

Post parameters

Parameter Required Description
hostsOnly false Endpoint will only return "hosts" data

Host object

Key Always returned type Description
name Yes String Host name.
type Yes String Either "premium" or "free". Premium hosts need a premium subscription.
domains Yes Array of String Host domains.
regexp Yes String Rgexp matching link format that Alldebrid supports.
status No Boolean Is the host currently (< 5 min) working on Alldebrid (only tested on some hosts, updated every ~ 10 min).

Domains only

<?php
$ch = curl_init('https://api.alldebrid.com/v4/hosts/domains');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl "https://api.alldebrid.com/v4/hosts/domains"

The above request returns JSON structured like this :

{
    "status": "success",
    "data": {
        "hosts": ["mega.nz", "mega.co.nz", "vimeo.com"],
        "streams": ["youtube.com", "youtu.be", "twitch.tv"],
        "redirectors": ["dl-protecte.com", "dl-protecte.org", "adf.ly"]
    }
}

Use this endpoint to only retrieve the list of supported hosts domains and redirectors as an array. This will also include any alternative domain the hosts or redirectors have. Please use regexps availables in /hosts or /user/hosts endpoints to validate supported links.

GET https://api.alldebrid.com/v4/hosts/domains

Hosts priority

<?php
$ch = curl_init('https://api.alldebrid.com/v4/hosts/priority');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl "https://api.alldebrid.com/v4/hosts/priority"

The above request returns JSON structured like this :

{
    "status": "success",
    "data": {
        "hosts": {
            "1fichier": 1,
            "4shared": 2,
            "backin": 3,
            "bdupload": 4
        }
    }
}

Not all hosts are created equal, so some hosts are more limited than other.

Use this endpoint to retrieve an ordered list of main domain of hosts, from more open to more restricted.

GET https://api.alldebrid.com/v4/hosts/priority

User

Informations

<?php
$ch = curl_init('https://api.alldebrid.com/v4/user');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" "http://api.alldebrid.com/v4/user" 

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "user": {
            "username": "MyUsername",
            "email": "some.email@example.com",
            "isPremium": true,
            "isSubscribed": false,
            "isTrial": false,
            "premiumUntil": "1545757200",
            "lang": "fr",
            "preferedDomain": "fr",
            "fidelityPoints": 200,
            "limitedHostersQuotas": {
                "someHost": 1024,
                "otherHost": 5000,
                "oneLast": 2000
            },
            "notifications": [ "FREEDAYS_USED_QUOTA" ]
        }
    }
}

Use this endpoint to get user informations.

HTTP Request

GET https://api.alldebrid.com/v4/user

Response attributes

Key Type Description
user Object User data.

User object

Key Always returned Type Description
username Yes String User username.
email Yes String User email.
isPremium Yes Boolean true is premium, false if not.
isSubscribed Yes Boolean true is user has active subscription, false if not.
isTrial Yes Boolean true is account is in freedays trial, false if not.
premiumUntil Yes Integer 0 if user is not premium, or timestamp until user is premium.
lang Yes String Language used by the user on Alldebrid, eg. 'en', 'fr'. Default to fr.
preferedDomain Yes String Preferer TLD used by the user, eg. 'fr', 'es'. Default to fr.
fidelityPoints Yes Integer Number of fidelity points.
limitedHostersQuotas Yes Array Remaining quotas for the limited hosts (in MB).
remainingTrialQuota No Integer When in trial mode, remaining global traffic quota available (in MB).
notifications Yes Array Codes of current notifications.

Available hosts

<?php
$ch = curl_init('https://api.alldebrid.com/v4/user/hosts');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" "http://api.alldebrid.com/v4/user/hosts" 

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "hosts": {
            "mega": {
                "name": "mega",
                "type": "premium",
                "domains": ["mega.nz", "mega.co.nz"],
                "regexp": "mega(\.co)?\.nz/([0-9a-zA-Z_]{20,36})",
                "status": true
            }
        },
        "streams": {
            "youtube": {
                "name": "youtube",
                "type": "free",
                "domains": [ "youtube.com", "youtu.be" ],
                "regexps": [ "https?:\/\/(?:www\\.)?youtube\\.com\/show\/(?P<id>[^?#]*)", "https?:\/\/(?:www\\.)?youtube\\.com\/feed\/history|:ythistory" ],
            }
        },
        "redirectors": {
            "protected": {
                "name": "protected",
                "type": "premium",
                "domains": ["protected.org", "protected.com"],
                "regexp": "(protected\.com/[0-9a-zA-Z]+)|(protected\.org/[0-9a-zA-Z]+)"
            }
        }
    }
}

This endpoint retrieves a complete list of all available hosts for this user. Depending of the account subscription status (free user, trial mode, premium user), the list and limitations will vary.

The limits and quota are updated in real time. Use this page to have an up-to-date list of service the user can use on Alldebrid.

Quotas will reset every day for premium users.

HTTP Request

GET https://api.alldebrid.com/v4/user/hosts

Post parameters

Parameter Required Description
hostsOnly false Endpoint will only return "hosts" data

Response attributes

Key Type Description
hosts Object Hosts infos.
streams Object Streaming websites infos.
redirectors Object Redirectors infos.

Host object

Key Always returned type Description
name Yes String Host name.
type Yes String Either "premium" or "free". Premium hosts need a premium subscription.
domains Yes Array Host domains.
regexps Yes Array Regexps matching the supported urls for this host.
status No Boolean Is the host currently (< 5 min) working on Alldebrid (only tested on some hosts, updated every ~ 10 min).
quota No Integer Remaining quota for this host, if any.
quotaMax No Integer Daily quota for this host, if any.
quotaType No String Specify if the quota is the remaining traffic available in MB ("traffic" type) or the number of remaining downloads possible ("nb_download" type)
limitSimuDl No Integer We limit the number of simultaneous downloads for some hosts, this will display the remaining download slot available for the user at this time.

Verification email status

<?php
$ch = curl_init('https://api.alldebrid.com/v4/user/verif');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'token' => 'verificationToken'
]));

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "token=verificationToken" "http://api.alldebrid.com/v4/user/verif" 

When receiving an AUTH_BLOCKED error formatted like this :

{
    "status": "error",
    "error": {
        "code": "AUTH_BLOCKED",
        "message": "You are logging from a new location, device or app. An <b>email has been sent<\/b> to confirm the new sign in.",
        "token": "verificationToken75ec0643f9eb0db"
    }
}

The above request returns JSON structured like this if waiting for mail confirmation :

{
    "status": "success",
    "data": {
        "verif": "waiting",
        "resendable": true,
    }
}

The above request returns JSON structured like this if connexion has been approved :

{
    "status": "success",
    "data": {
        "verif": "allowed",
        "apikey": "someValidApikey"
    }
}

The above request returns JSON structured like this if connexion has been denied :

{
    "status": "success",
    "data": {
        "verif": "denied"
    }
}

When connecting from a new place, you may be asked to verify this new connection for security measures. This include the API use.

If you trigguer such security, an email is sent to the user to confirm the new location. In those case, the api returns an AUTH_BLOCKED error, along with an token parameter as documented in the code example.

You can use this endpoint to track the status of the new connexion validation, and retreive the apikey when the request has been confirmed by email.

HTTP Request

POST https://api.alldebrid.com/v4/user/verif

Post parameters

Parameter Required Description
token true Verification token returned along with the AUTH_BLOCKED error

Response attributes

Key Always returned type Description
verif Yes String Verification status, either waiting, allowed or denied
resendable No Boolean Whether the verification email is resensable with /user/verif/resend, returned when verif = waiting
apikey No String The apikey, returned when verif = allowed

Specific errors

Code Description
PIN_EXPIRED Verification token is invalid

Resend verification email

<?php

$ch = curl_init('https://api.alldebrid.com/v4/user/verif/resend');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'token' => 'verificationToken'
]));

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "token=verificationToken" "http://api.alldebrid.com/v4/user/verif/resend" 

The above request returns JSON structured like this if email was sent :

{
    "status": "success",
    "data": {
        "sent": true
    }
}

Allow to send again the verification email, allowed once. We can referrer to the resendable property of the /user/verif response to know if you can request a resend.

HTTP Request

POST https://api.alldebrid.com/v4/user/verif/resend

Post parameters

Parameter Required Description
token true Verification token returned along with the AUTH_BLOCKED error

Response attributes

Key type Description
sent Boolean Email was sent again

Specific errors

Code Description
PIN_EXPIRED Verification token is invalid
ALREADY_SENT Verification email has already been se againnt

Clear notification

<?php
$ch = curl_init('https://api.alldebrid.com/v4/user/notification/clear');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'code' => 'NOTIF_CODE'
]));

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "code=NOTIF_CODE" "http://api.alldebrid.com/v4/user/notification/clear 

The above request returns JSON structured like this :

{
    "status": "success",
    "data": {
        "message": "Notification was cleared"
    }
}

This endpoint clears a user notification with its code. Current notifications codes can be retreive from the /user endpoint.

HTTP Request

POST https://api.alldebrid.com/v4/user/notification/clear

Post parameters

Parameter Required Description
code true Notification code to clear

Response attributes

Key Type Description
message String Clearing confirmation

Links

Informations

<?php

$ch = curl_init('https://api.alldebrid.com/v4/link/infos');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'link' => ["http://example.com/somefile", "http://notsupported.com/error"],
    'password' => 'optionalPassword',
]));

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "link[]=http://example.com/somefile" -F "link[]=http://notsupported.com/error" -F "password=optionalPassword" "http://api.alldebrid.com/v4/link/infos"

The single link request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "infos": [
            {
                "link": "http:\/\/example.com\/somefile",
                "filename": "somefile.txt",
                "size": 699400192,
                "host": "example",
                "hostDomain": "example.com",
            }
        ]
    }
}

The multiple links request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "infos": [
            {
                "link": "https:\/\/example.com\/somefile",
                "filename": "somefile.txt",
                "size": 699400192,
                "host": "example",
                "hostDomain": "example.com",

            },
            {
                "link": "http:\/\/notsupported.com/error",
                "error": {
                    "code": "LINK_HOST_NOT_SUPPORTED",
                    "message": "This host or link is not supported",
                }  
            }
        ]
    }
}

Use this endpoint to retrieve informations about a link. If it is in our systems, you'll have the filename and size (if available).

If the host is not supported or the link is down, an error will be returned for that link.

This endpoint only support host links, not redirectors links. Use the link/redirector endpoint for this.

HTTP Request

POST https://api.alldebrid.com/v4/link/infos

Post parameters

Parameter Required Type Description
link[] true array of string The array of links you request informations about.
password false string Link password.

Response attributes

Key Type Description
infos Array Array of info objects

Info object

Key Type Description
link string Requested link
filename string Link's file filename.
size Integer Link's file size in bytes.
host string Link host.
hostDomain string Host main domain
Code Description
LINK_IS_MISSING No link was sent
LINK_HOST_NOT_SUPPORTED This host or link is not supported
LINK_DOWN This link is not available on the file hoster website
LINK_PASS_PROTECTED Link is password protected
LINK_TEMPORARY_UNAVAILABLE link is temporary unavalible on hoster website

Redirectors

<?php
$ch = curl_init('https://api.alldebrid.com/v4/link/redirector');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'link' => "http://example.com/somefile"
]));

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "link=http://example.com/somefile" "http://api.alldebrid.com/v4/link/redirector"

The request returns JSON structured like this :

{
    "status": "success",
    "data": {
        "links": ["https:\/\/redirect.alldebrid.com\/mnsaj-0-fcdeaf3287a502c6e97359372afee2465043d9d8f7662f8ad18cbde0a882a42d", "https:\/\/redirect.alldebrid.com\/mnsaj-1-fcdeaf3287a502c6e97359372afee2465043d9d8f7662f8ad18cbde0a882a42d"]
    }
}

Use this endpoint to retrieve links protected by a redirector or link protector. Returned links will be encrypted (in the form https://redirect.alldebrid.com/mnsaj-0-fcdeaf3287a502c6e97359372afee2465043d9d8f7662f8ad18cbde0a882a42d) but will be usable on the /link/unlock endpoint.

Thos encrypted links are "virtual", as in they will only work when submitted to the link/unlock and link/infos endpoints (or used on /service/ on the main Website).

HTTP Request

POST https://api.alldebrid.com/v4/link/redirector

Post parameters

Parameter Required Type Description
link true string The redirector or protector link to extract links.

Response attributes

Key Type Description
links array Encrypted link(s) extracted.

Errors

Code Description
REDIRECTOR_NOT_SUPPORTED Redirector not supported.
REDIRECTOR_ERROR Could not extract links.
<?php

$ch = curl_init('https://api.alldebrid.com/v4/link/unlock');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'link' => "http://example.com/somefile",
    'password' => 'optionalPassword',
]));

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "link=http://example.com/somefile" -F "password=optionalPassword" "http://api.alldebrid.com/v4/link/unlock"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "link": "http:\/\/ombfyx.alld.io\/dl\/abcdefgh12\/somefile.txt",
        "host": "example",
        "filename": "somefile.txt",
        "paws": false,
        "filesize": 699400192,
        "streams": [
            //(...)
        ],
        "id": "abcdefgh12",
        "hostDomain": "example.com"
}

This endpoint unlocks a given link.

This endpoint can return a delayed ID. In that case, you must follow the delayed link flow.

HTTP Request

POST https://api.alldebrid.com/v4/link/unlock

Post parameters

Parameter Required Type Description
link true string The link to unlock.
password false string Link password.

Response attributes

Key Type Description
link String Requested link, simplified if it was not in canonical form.
filename string Link's file filename.
host String Link host minified.
streams Array List of alternative links with other resolutions for some video links. See code example for more infos.
paws Boolean Unused.
filesize Interger Filesize of the link's file.
id Integer Generation ID
hostDomain String Matched host main domain
delayed Integer Delayed ID if link need time to generate

Errors

Code Description
LINK_HOST_NOT_SUPPORTED This link is not supported.
LINK_DOWN This link is not available on the file hoster website.
LINK_HOST_UNAVAILABLE Host under maintenance or not available.
LINK_TOO_MANY_DOWNLOADS Too many concurrent downloads.
LINK_HOST_FULL All servers are full for this host, please retry later.
LINK_HOST_LIMIT_REACHED You have reached the download limit for this host.
LINK_PASS_PROTECTED Link is password protected.
LINK_ERROR Generic unlocking error.
LINK_NOT_SUPPORTED The link is not supported for this host.
LINK_TEMPORARY_UNAVAILABLE link is temporary unavalible on hoster website
MUST_BE_PREMIUM You must be premium to process this link.
FREE_TRIAL_LIMIT_REACHED You have reached the free trial limit (7 days // 25GB downloaded or host uneligible for free trial).
NO_SERVER Server are not allowed to use this feature. Visit https://alldebrid.com/vpn if you're using a VPN.
<?php
// Authentificated endpoint with valid apikey

$ch = curl_init('https://api.alldebrid.com/v4/link/unlock');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'link' => 'https://www.dailymotion.com/video/x8pnn16',
]));

$response = curl_exec($ch);
$linkInfos = json_decode($response, true);

curl_close($ch);

$id = $linkInfos['id'];
$stream = $linkInfos['streams'][0]['id'];

$ch = curl_init('https://api.alldebrid.com/v4/link/streaming');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'id' => $id,
    'stream' => $stream,
]));

$response = curl_exec($ch);
$streamLinkDLInfos = json_decode($response, true);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "id=123" -F "stream=streamId" "http://api.alldebrid.com/v4/link/streaming"

The first request to get stream links infos, returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "link": "",
        "host": "stream",
        "filename": "Rick Astley - Never Gonna Give You Up (Video)",
        "filesize": 0,
        "id": "1nsjw3315ad",
        "streams": [{
                "id": "140",
                "ext": "mp3",
                "quality": "mp3",
                "filesize": 3433538,
                "proto": "https",
                "name": "",
                "tb": 130.621,
                "abr": 128
            },
            {
                "id": "137+140",
                "ext": "mp4",
                "quality": 1080,
                "filesize": 75910363,
                "proto": "https",
                "name": ""
            },
            {
                "id": "398+140",
                "ext": "mp4",
                "quality": 720,
                "filesize": 32752789,
                "proto": "https",
                "name": ""
            },
        ]
    }
}

The second request returns JSON structured like this if successfull :

    "status": "success",
    "data": {
        "link": "https://p1cjev.alldeb.ovh/dl/1nsjw3315ad/Rick%20Astley%20-%20Never%20Gonna%20Give%20You%20Up%20%28Video%29.360.mp4",
        "filename": "Rick Astley - Never Gonna Give You Up (Video).360.mp4",
        "filesize": 113129149
    }
}

The second request returns JSON structured like this if successfull, is case of delayed link :

{
    "status": "success",
    "data": {
        "filename": "Rick Astley - Never Gonna Give You Up (Video).360.mp4",
        "filesize": 113129149,
        "delayed": 2277564
    }
}

The unlocking flow for streaming link is a bit more complex.

First hit the usual link/unlock endpoint. Two cases :

  1. Stream link has only one quality : downloading link is available immediatly.

OR

  1. Stream links has multiple qualities : you must select the desired quality to obtain a download link or delayed id by using the link/streaming endpoint.

Depending of the stream website, you'll either get a download link, or a delayed id (see Delayed link section for delayed links).

HTTP Request

POST https://api.alldebrid.com/v4/link/streaming

Post parameters

Parameter Required Type Description
id true string The link ID you received from the /link/unlock call.
stream true string The stream ID you choosed from the stream qualities list returned by /link/unlock.

Response attributes

Key Type Description
link String Optional. Download link, ONLY if available. This attribute WONT BE RETURNED if download link is a delayed link.
filename string Link's file filename.
filesize Interger Filesize of the link's file.
delayed Interger Optional. Delayed ID to get download link with delayed link flow (see next section)

Errors

Code Description
STREAM_INVALID_GEN_ID Invalid generation ID
STREAM_INVALID_STREAM_ID Invalid stream ID
<?php

$delayedID = 2457; // From /link/unlock

$ch = curl_init('https://api.alldebrid.com/v4/link/delayed');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'id' => $delayedID,
]));

$response = curl_exec($ch);
$result = json_decode($response, true);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "id=123" "http://api.alldebrid.com/v4/link/delayed"

The above request returns JSON structured like this if still delayed :

{
    "status": "success",
    "data": {
        "status": 1,
        "time_left": 45
    }
}

The above request returns JSON structured like this if link is available :

{
    "status": "success",
    "data": {
        "status": 2,
        "time_left": 0,
        "link": "http:\/\/ombfyx.alld.io\/dl\/abcdefgh12\/ubuntu-16.04.1-server-amd64.iso"
    }
}

This endpoint give the status of a delayed link.

Some links need time to generate, this endpoint send the status of such delayed links.

You should pool every 5 seconds or more the link/delayed endpoint until given the download link.

HTTP Request

POST https://api.alldebrid.com/v4/link/delayed

Post parameters

Parameter Required Type Description
id true integer Delayed ID received in /link/unlock.

Response attributes

Key Always returned Type Description
status Yes Integer Current status.
time_left Yes Integer Estimated time left to wait.
link No String Download link, available when it is ready.

Status code

Status Description
1 Still processing.
2 Download link is available.
3 Error, could not generate download link.

Errors

Code Description
DELAYED_INVALID_ID This delayed link id is invalid

Magnet

Upload magnet

Upload a magnet with its URI or hash.

You can either send the magnets in GET parameters, or in POST.

<?php
$magnet1 = 'magnet:?xt=urn:btih:842783e3005495d5d1637f5364b59343c7844707&dn=ubuntu-18.04.2-live-server-amd64.iso';
$magnet2 = '6be434d1f4ebefa14c4051e4bb0543cf47a8';
$magnet3 = '194257a7bf4eaea978f4b5b7fbd3b4efcdd99e43';

$ch = curl_init('https://api.alldebrid.com/v4/magnet/upload?apikey=E2XJrLFrlt30BW29qgqc');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'magnets' => [$magnet1, $magnet2, $magnet3],
]));

$response = curl_exec($ch);
$result = json_decode($response, true);
curl -X POST -H "Authorization: Bearer someValidApikeyYouGenerated" \
    -F "magnets[]=magnet:?xt=urn:btih:842783e3005495d5d1637f5364b59343c7844707&dn=ubuntu-18.04.2-live-server-amd64.iso" \
    -F "magnets[]=6be434d1f4ebefa14c4051e4bb0543cf47a8" \
    -F "magnets[]=194257a7bf4eaea978f4b5b7fbd3b4efcdd99e43" \
    "https://api.alldebrid.com/v4/magnet/upload?apikey=someValidApikeyYouGenerated"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "magnets" : [
            {
                "magnet": "magnet:?xt=urn:btih:842783e3005495d5d1637f5364b59343c7844707&dn=ubuntu-18.04.2-live-server-amd64.iso",
                "hash": "842783e3005495d5d1637f5364b59343c7844707",
                "name": "ubuntu-18.04.2-live-server-amd64.iso",
                "size": 875773970,
                "ready": true,
                "id": 123456
            },
            {
                "magnet": "6be434d1f4ebefa14c4051e4bb0543cf47a8",
                "error": {
                    "code": "MAGNET_INVALID_URI",
                    "message": "Magnet is not valid"
                }
            },
            {
                "magnet": "194257a7bf4eaea978f4b5b7fbd3b4efcdd99e43",
                "hash": "194257a7bf4eaea978f4b5b7fbd3b4efcdd99e43",
                "name": "ubuntu-18.04.3-live-server-amd64.iso",
                "size": 9024340026,
                "ready": true,
                "id": 234567
            }
        ]  
    }
}

HTTP Request

POST https://api.alldebrid.com/v4/magnet/upload

Post parameters

Parameter Required Type Description
magnets[] true array of string Magnet(s) URI or hash. Must send magnet either in GET param or in POST data.

Response attributes

Key Type Description
magnets Array Array of magnet objects

Magnet object

Key Type Description
magnet string Magnet sent.
name string Magnet filename, or 'noname' if could not parse it.
id integer Magnet id, used to query status.
hash string Magnet hash.
size integer Magnet files size.
ready boolean Whether the magnet is already available.

Endpoint errors

Code Description
MAGNET_NO_URI No magnet provided.
MAGNET_INVALID_URI Magnet is not valid.
MAGNET_MUST_BE_PREMIUM You must be premium to use this feature.
MAGNET_NO_SERVER Server are not allowed to use this feature. Visit https://alldebrid.com/vpn if you're using a VPN.
MAGNET_TOO_MANY_ACTIVE Already have maximum allowed active magnets (30).

Upload file

Upload torrent files.

This endpoint should be POSTed on. It expects a multipart formdata file upload.

<?php

$filePath = 'ubuntu-18.04.2-live-server-amd64.iso.torrent';
$file = new CURLFile($filePath, 'application/x-bittorrent');

$filePath2 = 'not.a.torrent.zip';
$file2 = new CURLFile($filePath2, 'application/x-bittorrent');

$ch = curl_init('https://api.alldebrid.com/v4/magnet/upload/file');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, ['files[0]' => $file, 'files[1]' => $file2 ]);

$result = curl_exec($ch);
curl -X POST -H "Authorization: Bearer someValidApikeyYouGenerated" \
    -F "files[]=@ubuntu-18.04.2-live-server-amd64.iso.torrent" \
    -F "files[]=@not.a.torrent.zip" \
    "https://api.alldebrid.com/v4/magnet/upload/file"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "files": [
            {
                "file": "ubuntu-18.04.2-live-server-amd64.iso.torrent",
                "name": "Ubuntu 18.04.2 live server amd64",
                "size": 1954210119,
                "hash": "842783e3005495d5d1637f5364b59343c7844707",
                "ready": false,
                "id": 123456
            },
            {
                "file": "not.a.torrent.zip",
                "error": {
                    "code": "MAGNET_INVALID_FILE",
                    "message": "File is not a valid torrent"
                }
            }
        ]
    }
}

HTTP Request

POST https://api.alldebrid.com/v4/magnet/upload/file

Post parameters

Parameter Required Type Description
files true array of files Magnet files.

Response attributes

Key Type Description
files array array of file objects

File object

Key Type Description
file string File name sent.
name string Torrent filename, or 'noname' if could not parse it.
hash string Torrent hash.
id integer Torrent id, used to query status.
size integer Torrent files size.
ready boolean Whether the torrent is already available.

Endpoint errors

Code Description
MAGNET_INVALID_FILE File is not a valid torrent
MAGNET_MUST_BE_PREMIUM You must be premium to use this feature.
MAGNET_NO_SERVER Server are not allowed to use this feature. Visit https://alldebrid.com/vpn if you're using a VPN.
MAGNET_TOO_MANY_ACTIVE Already have maximum allowed active magnets (30).
MAGNET_FILE_UPLOAD_FAILED File upload failed

Get Status

Get the status of current magnets, or only one if you specify a magnet ID.

<?php
$ch = curl_init('https://api.alldebrid.com/v4.1/magnet/status');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);

// Optional magnet id or status
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'id' => $magnetID,
    'status' => 'active',
]));

$response = curl_exec($ch);
$result = json_decode($response);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" "http://api.alldebrid.com/v4.1/magnet/status"

The above request could return JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "magnets": [
        {
            "id": 123456,
            "filename": "ubuntu-16.04.2-live-server-amd64.iso",
            "size": 587400285,
            "status": "Downloading",
            "statusCode": 1,
            "downloaded": 255400192,
            "uploaded": 0,
            "seeders": 7,
            "downloadSpeed": 18874368,
            "uploadSpeed": 0,
            "uploadDate": 1557133868,
            "completionDate" : 0,
        }, {
            "id": 56789,
            "filename": "ubuntu-20.04.2-live-server-amd64.iso",
            "size": 256400192,
            "status": "Ready",
            "statusCode": 4,
            "uploadDate": 1657133868,
            "completionDate" : 1657133968,
        }]
    }
}

HTTP Request

POST https://api.alldebrid.com/v4.1/magnet/status

Post parameters

Parameter Required Type Description
id false interger Magnet ID.
status false string Magnets status filter. Either active, ready, expired or error

Response attributes

Key Type Description
magnets array Array of magnet objects

Magnet object

Key Type Description
id integer Magnet id.
filename string Magnet filename.
size integer Magnet filesize.
status string Status in plain English.
statusCode integer Status code. See next table.
downloaded integer Downloaded data so far.
uploaded integer Uploaded data so far.
seeders integer Seeders count.
downloadSpeed integer Download speed.
uploadSpeed integer Upload speed.
uploadDate integer Timestamp of the date of the magnet upload.
completionDate integer Timestamp of the date of the magnet completion.
files array Magnet files, available if a specific magnet was requested. To request multiple magnet files, use the /magnets/files endpoint instead. The files tree structure is explained here.

Status code

Code Type Description
0 Processing In Queue.
1 Processing Downloading.
2 Processing Compressing / Moving.
3 Processing Uploading.
4 Finished Ready.
5 Error Upload fail.
6 Error Internal error on unpacking.
7 Error Not downloaded in 20 min.
8 Error File too big.
9 Error Internal error.
10 Error Download took more than 72h.
11 Error Deleted on the hoster website
12 Error Proccessing failed
13 Error Proccessing failed
14 Error Error while contacting tracker
15 Error File not available - no peer

Endpoint errors

Code Description
MAGNET_INVALID_ID Magnet ID is invalid.

Get Status - Live Mode

The Live Mode allows to only get the new data of the status of current magnets. It is designed to make a "live" panel or monitoring system more performant when consuming the magnet/status endpoint very frequently.

It requires a session ID and a counter, and using cache on the API side only the differences between the last state and the current state are sent, greatly reducing the amount of data returned by the API on each call.

The client using this mode must keep the current state of the magnets status locally between each call in order to apply the new data on the last state to get the whole current state.

A fixed session ID (integer) must be randomly set, and a counter starting at 0 will be used. On the first call (id=123, counter=0) with a new session ID, all the current data will be sent back, with the fullsync property set to true to make it clear, and the next counter to use. On the next call the updated counter is used (id=123, counter=1), and only the differences with the previous state will be send back.

If the magnets property returned is empty, then no change happened since the last call. If some changes happened, the magnets array will have some magnet objects (see Status) with its id and the properties changed, like this :

{ "id": 123456, "downloaded": 258879224, "downloadSpeed": 20587738 }

You can them apply those diff to the last state you kept to get the current magnets status state.

If you send a counter that is not in sync with the last call response (like sending the same counter twice in a row), then the endpoint will consider your counter invalid and will return a full fullsync reponse with a reseted counter.

If you want to see a live implementation of this mode, it is currently in use on the magnet dashboard on Alldebrid.

The above request could return JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "counter": 1,
        "fullsync": true,
        "magnets": [
        {
            "id": 123456,
            "filename": "ubuntu-16.04.2-live-server-amd64.iso",
            "size": 587400285,
            "status": "Downloading",
            "statusCode": 1,
            "downloaded": 255400192,
            "uploaded": 0,
            "seeders": 7,
            "downloadSpeed": 18874368,
            "uploadSpeed": 0,
            "uploadDate": 1557133868,
            "completionDate" : 0,
        }, {
            "id": 234567,
            "filename": "ubuntu-24.04.1-desktop-amd64.iso",
            "size": 6203355136,
            "status": "Ready",
            "statusCode": 4,
            "uploadDate": 1557133868,
            "completionDate" : 1557133968,
        },
        ],
    }
}
<?php
// Authentificated endpoint with valid apikey
$session = 123;
$counter = 0;

$ch = curl_init('https://api.alldebrid.com/v4.1/magnet/status');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);

// Optional magnet id or status
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'session' => $session,
    'counter' => $counter,
]));

$response = curl_exec($ch);
$result = json_decode($response);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "session=123456" -F "counter=0" "https://api.alldebrid.com/v4.1/magnet/status"

The above request could return JSON structured like this if successfull and some changes happened :

{
    "status": "success",
    "data": {
        "counter": 2,
        "magnets": [
            {
                "id": 123456,
                "downloaded": 258879224,
                "downloadSpeed": 20587738
            }
        ]
    }
}

The above request could return JSON structured like this if successfull but no change happended :

{
    "status": "success",
    "data": {
        "counter": 2,
        "magnets": []
    }
}

HTTP Request

POST https://api.alldebrid.com/v4.1/magnet/status

Post parameters

Parameter Required Type Description
session false interger Session ID
counter false interger Counter

Response attributes

Key Type Description
magnets array Array of magnet objects
counter integer Counter to use on the next call
fullsync boolean If returned to true, the response is the start of a new session, all data was returned and a new counter was set
<?php
// Authentificated endpoint with valid apikey
$magnetID = 123; // From magnet/status
$magnetID2 = 456;
$magnetID3 = 789;


$ch = curl_init('https://api.alldebrid.com/v4/magnet/files');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);

// Optional magnet id or status
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'id' => [ $magnetID, $magnetID2, $magnetID3 ]
]));

$response = curl_exec($ch);
$result = json_decode($response);

curl_close($ch);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "id=123456" "https://api.alldebrid.com/v4.1/magnet/files"

The above request could return JSON structured like this if successfull :

{
  "status": "success",
  "data": {
    "magnets": [
      {
        "id": "123",
        "files": [
          {
            "n": "ubuntu-24.10-desktop-amd64.iso",
            "s": 5665497088,
            "l": "https://alldebrid.com/f/xxxxxx"
          }
        ]
      },
      {
        "id": "456",
        "error": {
            "code": "MAGNET_INVALID_ID",
            "message": "This magnet ID does not exists or is invalid",
        }
      },
      {
        "id": "789",
        "files": [
          {
            "n": "Subfolder",
            "e": [
                {
                    "n": "subfile.txt",
                    "s": 112345,
                    "l": "https://alldebrid.com/f/xxxxxx"
                },
                {
                    "n": "Sub-sub folder",
                    "e": [
                        {
                            "n": "deep.file.txt",
                            "s": 456,
                            "l": "https://alldebrid.com/f/xxxxxx"
                        },
                        {
                            "n": "deep.file.2.txt",
                            "s": 7946,
                            "l": "https://alldebrid.com/f/xxxxxx"
                        },
                    ]
                },

            ]
          },
          {
            "n": "other.file.txt",
            "s": 123456,
            "l": "https://alldebrid.com/f/xxxxxx"
          },
          {
            "n": "third.file.txt",
            "s": 258147,
            "l": "https://alldebrid.com/f/xxxxxx"
          }
        ]
      },
    ]
  }
}

HTTP Request

POST https://api.alldebrid.com/v4/magnet/files

Post parameters

Parameter Required Type Description
id true array of integer Magnet ids

Response attributes

Key Type Description
magnets array Array of magnet objects

Magnet object

Key Type Description
id integer Magnet id
files array Array of files objects

Files property structure

Single file at root :

[{
    "n": "some.file.avi", 
    "s" : 45466546, 
    "l": "https://alldebrid.com/f/4564654"
}]

Single file in subfolder :

[{
    "n": "subfolderName",
    "e": [
        {
            "n": "some.file.avi", 
            "s" : 45466546, 
            "l": "https://alldebrid.com/f/4564654"
        }
    ]
}]

Single file in deeply nested subfolder :

[{
    "n": "subfolderName",
    "e": [
        {
        "n": "deepSubfolder",
        "e": [
            {
                "n": "some.file.avi", 
                "s" : 45466546, 
                "l": "https://alldebrid.com/f/4564654"
            }
        ]
        }
    ]
}]

Multiple files

[
    {
        "n": "subfolderName",
        "e": [
            {
                "n": "deepSubfolder",
                "e": [
                    {
                        "n": "some.file.txt", 
                        "s" : 456546, 
                        "l": "https://alldebrid.com/f/45654"
                    },
                ]
            },
            {
                "n": "otherSubfolder",
                "e": [
                    {
                        "n": "other.file.txt",
                        "s" : 12211, 
                        "l": "https://alldebrid.com/f/111111"
                    },
                ]
            }
        ]
    },
    {
        "n": "file.at.root.avi", 
        "s" : 1000000000, 
        "l": "https://alldebrid.com/f/5555555"
    }
]

files is an array of one or multiple objects representing the folder tree, with its sub-folders, sub-files and associated links. This format keeps the original magnet folder tree informations.

Folder node structure :

Parameter Type Description
n string name of the folder
e array sub-nodes

File node structure :

Parameter Type Description
n string filename
s int filesize
l string download link

Delete

Delete a magnet.

<?php

$magnetID = 123456;

$ch = curl_init('https://api.alldebrid.com/v4/magnet/delete');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'id' => $magnetID
]));

$response = curl_exec($ch);
$result = json_decode($response);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "id=123456" "https://api.alldebrid.com/v4/magnet/delete"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "message": "Magnet was successfully deleted"
    }
}

HTTP Request

POST https://api.alldebrid.com/v4/magnet/delete

Post parameters

Parameter Required Type Description
id true integer Magnet ID.

Endpoint errors

Code Description
MAGNET_INVALID_ID Magnet ID is invalid

Restart

Restart a failed magnet, or multiple failed magnets at once.

<?php

$magnetID = 123456;
$magnetID2 = 9123456;

$ch = curl_init('https://api.alldebrid.com/v4/magnet/restart');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'id' => $magnetID
]));

// Or multiple

curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'ids' => [$magnetID, $magnetID2 ]
]));

$response = curl_exec($ch);
$result = json_decode($response);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "id=123456" "https://api.alldebrid.com/v4/magnet/restart"
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "ids[]=123456" -F "ids[]=789012" "https://api.alldebrid.com/v4/magnet/restart"

The above request with one ID returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "message": "Magnet was successfully restarted"
    }
}

The above request with multipls IDs returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "magnets": [{
            "magnet": "81951197",
            "message": "Magnet was successfully restarted"
        }, {
            "magnet": "79101305",
            "error": {
                "code": "MAGNET_PROCESSING",
                "message": "Magnet is processing or completed"
            }
        }]   
    }
}

HTTP Request

POST https://api.alldebrid.com/v4/magnet/restart

Post parameters

Parameter Required Type Description
id false integer Magnet ID.
ids false array Array of Magnet ID.

Endpoint errors

Code Description
MAGNET_INVALID_ID Magnet ID is invalid
MAGNET_PROCESSING Magnet is processing or completed

User links

<?php

$ch = curl_init('https://api.alldebrid.com/v4/user/links');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);

$response = curl_exec($ch);
$result = json_decode($response);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" "https://api.alldebrid.com/v4/user/links"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "links": [
            {
                "link": "https:\/\/example.com\/somefile1",
                "filename": "somefile1.txt",
                "size": 751267520,
                "date": 1569420668,
                "host": "example"
            },
            {
                "link": "https:\/\/example.com\/somefile2",
                "filename": "somefile.txt",
                "size": 795126720,
                "date": 1569420668,
                "host": "example"
            },
            {
                "link": "http:\/\/youtube.com\/watch?v=dQw4w9WgXcQ",
                "filename": "",
                "size": 0,
                "date": 1583253075,
                "host": "stream"
            },
        ]
    }
}

Use this endpoint to get links the user saved for later use.

HTTP Request

GET https://api.alldebrid.com/user/links

Response attributes

Key Type Description
links Array Saved links.
Key Type Description
link String Link URL.
filename String Link file name.
size Integer Link file size.
date Integer When the link was saved.
host String Link host.

Save a link.

<?php

$myLink = 'https://example.com/somefile';
$myLink2 = 'https://example.com/somefile2';

$ch = curl_init('https://api.alldebrid.com/v4/user/links/save');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'links' => [ $myLink, $myLink2 ]
]));

$response = curl_exec($ch);
$result = json_decode($response);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "links[]=https://example.com/somefile" -F "links[]=https://example.com/somefile2" "https://api.alldebrid.com/v4/magnet/delete"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "message": "Link was successfully saved"
    }
}

HTTP Request

POST https://api.alldebrid.com/v4/user/links/save

Post parameters

Parameter Required Type Description
links true Arrayof string Links to save.

Delete a saved link.

<?php

$myLink = 'https://example.com/somefile';
$myLink2 = 'https://example.com/somefile2';

$ch = curl_init('https://api.alldebrid.com/v4/user/links/delete');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'links' => [ $myLink, $myLink2 ]
]));

$response = curl_exec($ch);
$result = json_decode($response);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "links[]=https://example.com/somefile" -F "links[]=https://example.com/somefile2" "https://api.alldebrid.com/v4/user/links/delete"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "message": "Link was successfully deleted"
    }
}

HTTP Request

POST https://api.alldebrid.com/v4/user/links/delete

Post parameters

Parameter Required Type Description
links false Array of String Links to delete.
<?php

$ch = curl_init('https://api.alldebrid.com/v4/user/history');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);

$response = curl_exec($ch);
$result = json_decode($response);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" "https://api.alldebrid.com/v4/user/history"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "links": [
            {
                "link": "https:\/\/example.com\/somefile",
                "filename": "somefile.txt",
                "size": 751267520,
                "date": 1569420668,
                "host": "example"
            },
            {
                "link": "https:\/\/example.com\/somefile2",
                "filename": "somefile2.txt",
                "size": 795126720,
                "date": 1569420668,
                "host": "example"
            },
            {
                "link": "http:\/\/youtube.com\/watch?v=dQw4w9WgXcQ",
                "filename": "",
                "size": 0,
                "date": 1583253075,
                "host": "stream"
            },
        ]
    }
}

Use this endpoint to get recent links. Recent link logging being disabled by default, this will return nothing until history logging has been activated in your account settings.

Links older than 3 days are automatically deleted from the recent history. To keep links in your account, use the Saved links.

HTTP Request

GET https://api.alldebrid.com/user/history

Response attributes

Key Type Description
links Array Saved links.
Key Type Description
link String Link URL.
filename String Link file name.
size Integer Link file size.
date Integer When the link was saved.
host String Link host.
<?php

$ch = curl_init('https://api.alldebrid.com/v4/user/history/delete');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);

$response = curl_exec($ch);
$result = json_decode($response);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST "https://api.alldebrid.com/v4/user/history/delete'"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "message": "Links were successfully deleted"
    }
}

Use this endpoint to delete all links currently in your recent links history. Links older than 3 days are automatically deleted from the recent history.

HTTP Request

POST https://api.alldebrid.com/user/history/delete

Resellers Vouchers

Accredited Alldebrid reseller can use these endpoints to manage vouchers and check their current balance.

Balance

<?php

$ch = curl_init('https://api.alldebrid.com/v4/voucher/balance');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);

$response = curl_exec($ch);
$result = json_decode($response);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" "https://api.alldebrid.com/v4/voucher/balance"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "balance": 51.6
    }
}

Use this endpoint to get your current reseller balance.

HTTP Request

GET https://api.alldebrid.com/voucher/balance

Response attributes

Key Type Description
balance Float Current reseller balance.

Get Vouchers

<?php

$ch = curl_init('https://api.alldebrid.com/v4/voucher/get');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'duration' => 30,
    'nb' => 5
]));

$response = curl_exec($ch);
$result = json_decode($response);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "duration=30" -F "nb=5" "https://api.alldebrid.com/v4/voucher/get"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "codes": [
            "AAAAAA-BBBBBB-CCCCCC-DDDDDD",
            "EEEEEE-FFFFFF-GGGGGG-HHHHHH",
            "IIIIII-JJJJJJ-KKKKKK-LLLLLL"
        ]
    }
}

The partial list request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "codes": [
            "MMMMMM-NNNNNN-OOOOOO-PPPPPP",
            "QQQQQQ-RRRRRR-SSSSSS-TTTTTT",
            "UUUUUU-VVVVVV-WWWWWW-XXXXXX",
            "YYYYYY-ZZZZZZ-111111-222222",
            "333333-444444-555555-666666",
            "777777-888888-999999-000000"
        ],
        "partialList": true
    }
}

Use this endpoint to get available vouchers from your reseller account. You must specify a duration and a voucher number. If some voucher request are available but not enough to fulfill the requested number, a partial list will be return with the associated response property set. If no voucher are available, an error will be returned.

HTTP Request

POST https://api.alldebrid.com/voucher/get

Post parameters

Parameter Required Description
duration true One of the current voucher duration (15, 30, 90, 180, 365)
nb true Number of voucher to get, between 1 and 10.

Response attributes

Key Type Description
codes Array Array of generated vouchers.
partialList Boolean Return as true if reseller account doesn't have enough voucher to fulfill request.

Endpoint errors

Code Description
VOUCHER_DURATION_INVALID Invalid voucher duration (must be either 15, 30, 90, 180 or 365)
VOUCHER_NB_INVALID Invalid voucher number, must be between 1 and 10
NO_MORE_VOUCHER No voucher of this type available in your account

Balance

<?php

$ch = curl_init('https://api.alldebrid.com/v4/voucher/generate');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Authorization: Bearer someValidApikeyYouGenerated']);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
    'duration' => 30,
    'nb' => 2
]));

$response = curl_exec($ch);
$result = json_decode($response);
curl -H "Authorization: Bearer someValidApikeyYouGenerated" -X POST -F "duration=30" -F "nb=5" "https://api.alldebrid.com/v4/voucher/generate"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "codes": [
            "AAAAAA-BBBBBB-CCCCCC-DDDDDD",
            "EEEEEE-FFFFFF-GGGGGG-HHHHHH",
            "IIIIII-JJJJJJ-KKKKKK-LLLLLL"
        ],
        "pricePerVoucher": 3.2,
        "total": 9.6,
        "balance": 18.21
    }
}

Use this endpoint to get available vouchers from your reseller account. You must specify a duration and a voucher number.

HTTP Request

POST https://api.alldebrid.com/voucher/generate

Post parameters

Parameter Required Description
duration true One of the current voucher duration (15, 30, 90, 180, 365)
nb true Number of voucher to generate, between 1 and 10.

Response attributes

Key Type Description
codes Array Array of generated vouchers.
pricePerVoucher Float Price paid per voucher.
total Float Total price for the request.
balance Float Current reseller balance after vouchers generation.

Endpoint errors

Code Description
VOUCHER_DURATION_INVALID Invalid voucher duration (must be either 15, 30, 90, 180 or 365)
VOUCHER_NB_INVALID Invalid voucher number, must be between 1 and 10
INSUFFICIENT_BALANCE Your current reseller balance is not enough to generate the requested vouchers.

Deprecated endpoints

When an endpoint get a major update, it's api version is bumped and the old endpoint is flaggued as deprectated. Those deprecated endpoints return a deprecated flag alongside the status property.

Deprecated endpoint documentation can be found below.

/v4/ Get pin

<?php

$ch = curl_init('https://api.alldebrid.com/v4/pin/get');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$response = curl_exec($ch);
$pinInfo = json_decode($response, true);

curl_close($ch);
curl "https://api.alldebrid.com/v4/pin/get"

The above request returns JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "pin": "ABCD",
        "check": "664c3ca2635c99f291d28e11ea18e154750bd21a",
        "expires_in": 600,
        "user_url": "https:\/\/alldebrid.com\/pin\/?pin=ABCD",
        "base_url": "https:\/\/alldebrid.com\/pin\/",
        "check_url": "https:\/\/api.alldebrid.com\/pin\/check?check=664c3ca2635c99f291d28e11ea18e154750bd21a&pin=ABCD&agent=myAppName"
    }
}

HTTP Request

GET https://api.alldebrid.com/v4/pin/get

Response attributes

Key Type Description
pin String Pin code to display to your user
check String Check token needed for the pin/check endpoint
expires_in Integer Number of second before the code expire
user_url String Url to display with PIN included
base_url String Base url
check_url String Endpoint to pool to get auth apikey once user submitted the PIN code

/v4/ Magnet Status

Get the status of current magnets, or only one if you specify a magnet ID.

<?php
$context = stream_context_create([ 'http' => [ 'ignore_errors' => true ] ]); // Suppress PHP warnings on HTTP status code >= 400

// Authentificated endpoint with valid apikey
$magnetID = 123456;
$apiEndpoint = "https://api.alldebrid.com/v4/magnet/status?apikey=someValidApikeyYouGenerated";
$apiEndpointOnlyOne = "https://api.alldebrid.com/v4/magnet/status?apikey=someValidApikeyYouGenerated&id=" . urlencode($magnetID);
$apiEndpointOnlyActive = "https://api.alldebrid.com/v4/magnet/status?apikey=someValidApikeyYouGenerated&status=active";

$response = json_decode(file_get_contents($apiEndpoint, false, $context));
curl -G --data-urlencode "id=123456" "https://api.alldebrid.com/v4/magnet/status?apikey=someValidApikeyYouGenerated"

The above request could return JSON structured like this if successfull :

{
    "status": "success",
    "deprecated": true,
    "data": {
        "magnets": [
        {
            "id": 123456,
            "filename": "ubuntu-16.04.2-live-server-amd64.iso",
            "size": 587400285,
            "status": "Downloading",
            "statusCode": 1,
            "downloaded": 255400192,
            "uploaded": 0,
            "seeders": 7,
            "downloadSpeed": 18874368,
            "uploadSpeed": 0,
            "uploadDate": 1557133868,
            "completionDate" : 0,
            "links": []
        }, {
            "id": 56789,
            "filename": "ubuntu-20.04.2-live-server-amd64.iso",
            "size": 256400192,
            "status": "Ready",
            "statusCode": 4,
            "downloaded": 256400192,
            "uploaded": 0,
            "seeders": 12,
            "downloadSpeed": 0,
            "uploadSpeed": 0,
            "uploadDate": 1657133868,
            "completionDate" : 1657133968,
            "links": [
                {
                    "link": "https:\/\/alldebrid.com\/f\/aaaabbbbzzzz",
                    "filename": "ubuntu-20.04.2-live-server-amd64.iso",
                    "size": 256458252,
                    "files": [
                        {
                            "n": "ubuntu-20.04.2-live-server-amd64.iso"
                        }
                    ]
                },
                {
                    "link": "https:\/\/alldebrid.com\/f\/aaaabbbbqqqq",
                    "filename": "ubuntu-20.04.2-full-package-server-amd64.iso",
                    "size": 256458252,
                    "files": [
                        {
                            "n": "full-package",
                            "e": [
                                {
                                    "n": "ubuntu-20.04.2-full-server-amd64.iso"
                                }
                            ]
                        }
                    ]
                },
                {
                    "link": "https:\/\/alldebrid.com\/f\/aaaabbbbxxxx",
                    "filename": "ubuntu-20.04.2-live-server-amd64.rar",
                    "size": 7845117,
                    "files": [
                        {
                            "n": "docs",
                            "e": [
                                {
                                    "n": "README.txt"
                                },
                                {
                                    "n": "INSTALL.txt"
                                },
                                {
                                    "n": "french",
                                    "e": [
                                        {
                                            "n": "LISEZ-MOI.txt"
                                        },
                                        {
                                            "n": "INSTALLATION.txt"
                                        }
                                    ]
                                }
                            ]
                        },
                        {
                            "n": "some.other.file.in.root.folder.zip",
                        }
                    ]
                }
            ],
        }]
    }
}

HTTP Request

POST https://api.alldebrid.com/v4/magnet/status

Post parameters

Parameter Required Type Description
id false interger Magnet ID.
status false string Magnets status filter. Either active, ready, expired or error
session false interger Session ID for Live mode (see Live Mode).
counter false interger Counter for Live mode (see Live Mode).

Response attributes

Key Type Description
magnets array Array of magnet objects

Magnet object

Key Type Description
id integer Magnet id.
filename string Magnet filename.
size integer Magnet filesize.
status string Status in plain English.
statusCode integer Status code. See next table.
downloaded integer Downloaded data so far.
uploaded integer Uploaded data so far.
seeders integer Seeders count.
downloadSpeed integer Download speed.
uploadSpeed integer Upload speed.
uploadDate integer Timestamp of the date of the magnet upload.
completionDate integer Timestamp of the date of the magnet completion.
links array of object an array of link objects
Key Type Description
link integer Download link
filename string File name
size integer File size.
files array different format depending of version property

files is an array of 1 or multiple objects representing the folder and files of the file or files. This format keep folder path informations.

Each object always have a name n string property, and an entries e array property if the object represent a folder.

Single file at root : [{"n": "some.file.avi"}]

Single file in subfolder : [{ "n": "subfolderName", "e": [ {"n": "some.file.avi"} ] }]

Single file in deeply nested subfolder : [{ "n": "subfolderName", "e": [{ "n": "deepSubfolder", "e": [ {"n": "some.file.avi"} ] }] }]

Multiple files [ { "n": "subfolderName", "e": [ {"n": "some.file.txt"}, { "n": "deepSubfolder", "e": [ {"n": "some.file.txt"}, {"n": "some.file2.doc"}, {"n": "some.file3.doc"} ] }, { "n": "otherSubfolder", "e": [ {"n": "other.file.txt"}, {"n": "other.file2.doc"} ] } ] }, {"n": "file.at.root.avi"} ]

Status code

Code Type Description
0 Processing In Queue.
1 Processing Downloading.
2 Processing Compressing / Moving.
3 Processing Uploading.
4 Finished Ready.
5 Error Upload fail.
6 Error Internal error on unpacking.
7 Error Not downloaded in 20 min.
8 Error File too big.
9 Error Internal error.
10 Error Download took more than 72h.
11 Error Deleted on the hoster website

Endpoint errors

Code Description
MAGNET_INVALID_ID Magnet ID is invalid.

/v4/ Magnet Status - Live Mode

The Live Mode allows to only get the new data of the status of current magnets. It is designed to make a "live" panel or monitoring system more performant when consuming the magnet/status endpoint very frequently.

It requires a session ID and a counter, and using cache on the API side only the differences between the last state and the current state are sent, greatly reducing the amount of data returned by the API on each call.

The client using this mode must keep the current state of the magnets status locally between each call in order to apply the new data on the last state to get the whole current state.

A fixed session ID (integer) must be randomly set, and a counter starting at 0 will be used. On the first call (id=123, counter=0) with a new session ID, all the current data will be sent back, with the fullsync property set to true to make it clear, and the next counter to use. On the next call the updated counter is used (id=123, counter=1), and only the differences with the previous state will be send back.

If the magnets property returned is empty, then no change happened since the last call. If some changes happened, the magnets array will have some magnet objects (see Status) with its id and the properties changed, like this :

{ "id": 123456, "downloaded": 258879224, "downloadSpeed": 20587738 }

You can them apply those diff to the last state you kept to get the current magnets status state.

If you send a counter that is not in sync with the last call response (like sending the same counter twice in a row), then the endpoint will consider your counter invalid and will return a full fullsync reponse with a reseted counter.

If you want to see a live implementation of this mode, it is currently in use on the magnet dashboard on Alldebrid.

<?php
$context = stream_context_create([ 'http' => [ 'ignore_errors' => true ] ]); // Suppress PHP warnings on HTTP status code >= 400

// Authentificated endpoint with valid apikey
$session = 123;
$counter = 0;

$apiEndpoint = "https://api.alldebrid.com/v4/magnet/status?apikey=someValidApikeyYouGenerated&session=" . urlencode($session) . "&counter=" . urlencode($counter);

$response = json_decode(file_get_contents($apiEndpoint, false, $context));


curl -G --data-urlencode "id=123456" "https://api.alldebrid.com/v4/magnet/status?apikey=someValidApikeyYouGenerated&session=123&counter=0"

The above request could return JSON structured like this if successfull :

{
    "status": "success",
    "data": {
        "counter": 1,
        "fullsync": true,
        "magnets": [
        {
            "id": 123456,
            "filename": "ubuntu-16.04.2-live-server-amd64.iso",
            "size": 587400285,
            "status": "Downloading",
            "statusCode": 1,
            "downloaded": 255400192,
            "uploaded": 0,
            "seeders": 7,
            "downloadSpeed": 18874368,
            "uploadSpeed": 0,
            "uploadDate": 1557133868,
            "completionDate" : 0,
            "links": []
        }, {
            "id": 234567,
            "filename": "ubuntu-18.04.2-live-server-amd64.iso",
            "size": 699400192,
            "status": "Ready",
            "statusCode": 4,
            "downloaded": 699400192,
            "uploaded": 0,
            "seeders": 7,
            "downloadSpeed": 0,
            "uploadSpeed": 0,
            "uploadDate": 1557133868,
            "completionDate" : 1557133968,
            "links": [
                {
                    "link": "https:\/\/alldebrid.com\/f\/aaaabbbbcccc",
                    "filename": "ubuntu-18.04.2-live-server-amd64.iso",
                    "size": 685458252,
                    "files": null
                },
                {
                    "link": "https:\/\/alldebrid.com\/f\/aaaabbbbdddd",
                    "filename": "ubuntu-18.04.2-live-server-amd64.rar",
                    "size": 7845117,
                    "files": [
                        "README.txt",
                        "some.other.file.zip"
                    ]
                }
            ],
        }]
    }
}
<?php
$context = stream_context_create([ 'http' => [ 'ignore_errors' => true ] ]); // Suppress PHP warnings on HTTP status code >= 400

// Authentificated endpoint with valid apikey
$session = 123;
$counter = 1;

$apiEndpoint = "https://api.alldebrid.com/v4/magnet/status?apikey=someValidApikeyYouGenerated&session=" . urlencode($session) . "&counter=" . urlencode($counter);

$response = json_decode(file_get_contents($apiEndpoint, false, $context));


curl -G --data-urlencode "id=123456" "https://api.alldebrid.com/v4/magnet/status?apikey=someValidApikeyYouGenerated&session=123&counter=1"

The above request could return JSON structured like this if successfull and some changes happened :

{
    "status": "success",
    "data": {
        "counter": 2,
        "magnets": [
            {
                "id": 123456,
                "downloaded": 258879224,
                "downloadSpeed": 20587738
            }
        ]
    }
}

The above request could return JSON structured like this if successfull but no change happended :

{
    "status": "success",
    "data": {
        "counter": 2,
        "magnets": []
    }
}

HTTP Request

GET https://api.alldebrid.com/v4/magnet/status?apikey=someValidApikeyYouGenerated&session=123&counter=0

GET https://api.alldebrid.com/v4/magnet/status?apikey=someValidApikeyYouGenerated&session=123&counter=1

Post parameters

Parameter Required Type Description
apikey true string User apikey.
session false interger Session ID
counter false interger Counter

Response attributes

Key Type Description
magnets array Array of magnet objects
counter integer Counter to use on the next call
fullsync boolean If returned to true, the response is the start of a new session, all data was returned and a new counter was set

All errors

<?php
$apiErrors = [
    "GENERIC" => "An orror occured",
    "404" => "Endpoint doesn't exist",
    "MAINTENANCE" => "Alldebrid is under maintenance, please retry later",
    "AUTH_MISSING_APIKEY" => "The auth apikey was not sent",
    "AUTH_BAD_APIKEY" => "The auth apikey is invalid",
    "AUTH_BLOCKED" => "This apikey is geo-blocked or ip-blocked",
    "AUTH_USER_BANNED" => "This account is banned",
    "ALREADY_SENT" => "The verification email has already been sent again",
    "NO_SERVER" => "Servers are not allowed to use this feature. Visit https://alldebrid.com/vpn if you're using a VPN.",
    "LINK_IS_MISSING" => "No link was sent",
    "BAD_LINK" => "Sent link in not valid",
    "LINK_HOST_NOT_SUPPORTED" => "This host or link is not supported",
    "LINK_DOWN" => "This link is not available on the file hoster website",
    "LINK_PASS_PROTECTED" => "Link is password protected",
    "LINK_HOST_UNAVAILABLE" => "Host under maintenance or not available",
    "LINK_TOO_MANY_DOWNLOADS" => "Too many concurrent downloads for this host",
    "LINK_HOST_FULL" => "All servers are full for this host, please retry later",
    "LINK_HOST_LIMIT_REACHED" => "You have reached the download limit for this host",
    "LINK_ERROR" => "Could not unlock this link",
    "LINK_TEMPORARY_UNAVAILABLE" => "The link is temporary unavalible on the website",
    "LINK_NOT_SUPPORTED" => "The link is not supported for this host",
    "REDIRECTOR_NOT_SUPPORTED" => "Redirector not supported",
    "REDIRECTOR_ERROR" => "Could not extract links",
    "STREAM_INVALID_GEN_ID" => "Invalid generation ID",
    "STREAM_INVALID_STREAM_ID" => "Invalid stream ID",
    "DELAYED_INVALID_ID" => "This delayed link id is invalid",
    "FREE_TRIAL_LIMIT_REACHED" => "You have reached the free trial limit (7 days / 25GB downloaded or host uneligible for free trial)",
    "MUST_BE_PREMIUM" => "You must be premium to process this link",
    "MAGNET_INVALID_ID" => "This magnet ID does not exists or is invalid",
    "MAGNET_INVALID_URI" => "Magnet is not valid",
    "MAGNET_INVALID_FILE" => "File is not a valid torrent",
    "MAGNET_FILE_UPLOAD_FAILED" => "File upload failed",
    "MAGNET_NO_URI" => "No magnet sent",
    "MAGNET_PROCESSING" => "Magnet is processing or completed",
    "MAGNET_TOO_MANY_ACTIVE" => "Already have maximum allowed active magnets (30)",
    "MAGNET_TOO_MANY" => "Magnets limit reached (1000 accross all tabs)",
    "MAGNET_MUST_BE_PREMIUM" => "You must be premium to use this feature",
    "MAGNET_TOO_LARGE" => "Magnet files are too large (max 1TB)",
    "MAGNET_UPLOAD_FAILED" => "Upload fail",
    "MAGNET_INTERNAL_ERROR" => "Internal error",
    "MAGNET_CANT_BOOTSTRAP" => "Not downloaded in 20 min",
    "MAGNET_MAGNET_TOO_BIG" => "File too big, more than 1TB",
    "MAGNET_TOOK_TOO_LONG" => "Download took more than 72h",
    "MAGNET_LINKS_REMOVED" => "Removed from hoster website",
    "MAGNET_PROCESSING_FAILED" => "Proccessing failed (bad torrent ?)",
    "PIN_ALREADY_AUTHED" => "You already have a valid auth apikey",
    "PIN_EXPIRED" => "The pin is expired",
    "PIN_INVALID" => "The pin is invalid",
    "USER_LINK_MISSING" => "No link provided",
    "USER_LINK_INVALID" => "Can't save those links",
    "MISSING_NOTIF_ENDPOINT" => "You must provide an endpoint to unsubscribe",
    "VOUCHER_DURATION_INVALID" => "Duration is invalid",
    "VOUCHER_NB_INVALID" => "Voucher number is invalid",
    "NO_MORE_VOUCHER" => "No more available vouchers for this duration",
    "INSUFFICIENT_BALANCE" => "No enough balance",
    "DOWNLOAD_FAILED" => "Download failed",
    "ACCOUNT_INVALID" => "This account doens't have access to this endpoint",
    "NO_JSON_PARAM" => "Missing json payload",
    "JSON_INVALID" => "json payload is not valid JSON",
    "FREEDAYS_INVALID_COUNTRY" => "Invalid country code",
    "FREEDAYS_INVALID_PHONE" => "Invalid phone",
    "FREEDAYS_INVALID_PROVIDER" => "Invalid provider",
    "FREEDAYS_USED_PHONE" => "Phone number already used",
    "FREEDAYS_ALREADY_REQUESTED" => "A freedays request has already been started",
    "FREEDAYS_INVALID_STATUS" => "Bad status",
    "FREEDAYS_TOO_MUCH_RETRIES" => "Too much retries",
    "FREEDAYS_INVALID_CODE" => "Invalid code",
    "FREEDAYS_DENIED" => "Freedays can't be activated",
    "FREEDAYS_ERROR_SENDING" => "Could not send the message",
];

You can find all possible errors here, available in PHP array and JSON format if needed.

Some errors will return an HTTP code 401 or 429, depending of the error.

Code Description
GENERIC An orror occured
404 Endpoint doesn't exist
MAINTENANCE Alldebrid is under maintenance, please retry later
AUTH_MISSING_APIKEY The auth apikey was not sent
AUTH_BAD_APIKEY The auth apikey is invalid
AUTH_BLOCKED This apikey is geo-blocked or ip-blocked
AUTH_USER_BANNED This account is banned
ALREADY_SENT The verification email has already been sent again
NO_SERVER Servers are not allowed to use this feature. Visit https://alldebrid.com/vpn if you're using a VPN.
LINK_IS_MISSING No link was sent
BAD_LINK Sent link in not valid
LINK_HOST_NOT_SUPPORTED This host or link is not supported
LINK_DOWN This link is not available on the file hoster website
LINK_PASS_PROTECTED Link is password protected
LINK_HOST_UNAVAILABLE Host under maintenance or not available
LINK_TOO_MANY_DOWNLOADS Too many concurrent downloads for this host
LINK_HOST_FULL All servers are full for this host, please retry later
LINK_HOST_LIMIT_REACHED You have reached the download limit for this host
LINK_ERROR Could not unlock this link
LINK_TEMPORARY_UNAVAILABLE The link is temporary unavalible on the website
LINK_NOT_SUPPORTED The link is not supported for this host
REDIRECTOR_NOT_SUPPORTED Redirector not supported
REDIRECTOR_ERROR Could not extract links
STREAM_INVALID_GEN_ID Invalid generation ID
STREAM_INVALID_STREAM_ID Invalid stream ID
DELAYED_INVALID_ID This delayed link id is invalid
FREE_TRIAL_LIMIT_REACHED You have reached the free trial limit (7 days / 25GB downloaded or host uneligible for free trial)
MUST_BE_PREMIUM You must be premium to process this link
MAGNET_INVALID_ID This magnet ID does not exists or is invalid
MAGNET_INVALID_URI Magnet is not valid
MAGNET_INVALID_FILE File is not a valid torrent
MAGNET_FILE_UPLOAD_FAILED File upload failed
MAGNET_NO_URI No magnet sent
MAGNET_PROCESSING Magnet is processing or completed
MAGNET_TOO_MANY_ACTIVE Already have maximum allowed active magnets (30)
MAGNET_TOO_MANY Magnets limit reached (1000 accross all tabs)
MAGNET_MUST_BE_PREMIUM You must be premium to use this feature
MAGNET_TOO_LARGE Magnet files are too large (max 1TB)
MAGNET_UPLOAD_FAILED Upload fail
MAGNET_INTERNAL_ERROR Internal error
MAGNET_CANT_BOOTSTRAP Not downloaded in 20 min
MAGNET_MAGNET_TOO_BIG File too big, more than 1TB
MAGNET_TOOK_TOO_LONG Download took more than 72h
MAGNET_LINKS_REMOVED Removed from hoster website
MAGNET_PROCESSING_FAILED Proccessing failed (bad torrent ?)
PIN_ALREADY_AUTHED You already have a valid auth apikey
PIN_EXPIRED The pin is expired
PIN_INVALID The pin is invalid
USER_LINK_MISSING No link provided
USER_LINK_INVALID Can't save those links
MISSING_NOTIF_ENDPOINT You must provide an endpoint to unsubscribe
VOUCHER_DURATION_INVALID Duration is invalid
VOUCHER_NB_INVALID Voucher number is invalid
NO_MORE_VOUCHER No more available vouchers for this duration
INSUFFICIENT_BALANCE No enough balance
DOWNLOAD_FAILED Download failed
ACCOUNT_INVALID This account doens't have access to this endpoint
NO_JSON_PARAM Missing json payload
JSON_INVALID json payload is not valid JSON
FREEDAYS_INVALID_COUNTRY Invalid country code
FREEDAYS_INVALID_PHONE Invalid phone
FREEDAYS_INVALID_PROVIDER Invalid pro16/10/2024

Changelog

15/01/2025

17/10/2024

16/10/2024

14/11/2023

16/08/2023

15/08/2023

07/12/2022

10/04/2022

06/04/2021

21/08/2020

31/07/2020

22/07/2020

30/03/2020

27/03/2020

26/03/2020

04/03/2020

03/03/2020

01/03/2020

28/02/2020

01/02/2020

31/07/2020

22/07/2020

30/03/2020

27/03/2020

26/03/2020

04/03/2020

--