Do the first three steps in Gcore Customer Portal on the Secure token tab.
1. Enable the "Secure token" option in the resource settings.
2. Enter a key that contains between 6 and 32 characters.
3. If you want your content to be accessible from any IP address, leave the "Add a client's IP to the token" unchecked. If you want to make your content available only from one IP, check the checkbox (you will specify the allowlisted IP address later at Step 4).
4. Do this step on your origin server. Insert a script on your website which generates secure links. The generated links should look like as below:
Where:
http://cdn.example.com/photo.jpeg
is the path to the file,DMF1ucDxtHCxwYQ
is the output of the "MD5(String)" hash function, where String is the parameter obtained by merging elements: <link expiry time><file path><allowlisted IP address><key from Step 2>
,2147483647
is the time in the UNIX timestamp format until which the link is considered valid.
We have prepared script templates for PHP, Python, and OpenSSL — just copy one of them from the "Scripts for link generation" section below. The script will start creating secure links to the content.
5. Do this step on your origin server. Arrange the content on your website to allow access to the protected files only over a secured link — that is, rule out the delivery of the required content over a link without a secure token.
Moreover, make sure our CDN can access the content on your origin server regardless of whether a key is present or not.
Below is the script for creating temporary links with the IP-based access restriction. The files will be accessible only from an allowlisted IP address and only until the link expires.
<?php
$secret = 'secret_key';
$ip = '1.2.3.4';
$path = '/live/133529_2/chunklist.m3u8';
$expires = time() + 10000;
$link = "$expires$path$ip $secret";
$md5 = md5($link, true);
$md5 = base64_encode($md5);
$md5 = strtr($md5, '+/', '-_');
$md5 = str_replace('=', '', $md5);
$url = "http://cdn.site.com{$path}?md5={$md5}&expires={$expires}";
echo $url;
echo "\n";
Below is the script for creating temporary links without any IP-based access restriction. The files will be accessible from any IP address, but only until the link expires.
<?php
$secret = 'secret_key';
$path = '/live/133529_2/chunklist.m3u8';
$expires = time() + 10000;
$link = "$expires$path $secret";
$md5 = md5($link, true);
$md5 = base64_encode($md5);
$md5 = strtr($md5, '+/', '-_');
$md5 = str_replace('=', '', $md5);
$url = "http://cdn.site.com{$path}?md5={$md5}&expires={$expires}";
echo $url;
echo "\n"
In these scripts:
The script for creating temporary links with the IP-based access restriction. The files will be accessible only from an allowlisted IP address and only until the link expires.
import base64
from hashlib import md5
from time import timesecret = 'secret_key'
path = "/images/1.jpg"
ip = '1.2.3.4'
# TTL of URL (in sec)
ttl = 100000
expires = int(time()) + ttl#Token generation
token_hash = md5(f"{expires}{path}{ip} {secret}".encode()).digest()
token = base64.b64encode(token_hash).decode().replace("\n", "").replace("+", "-").replace("/", "_").replace("=", "")
secured_url = f"http://cdn.site.com{path}?md5={token}&expires={expires}"# File's URL
print(secured_url)
Below is the script for creating temporary links without any IP-based access restriction. The files will be accessible from any IP address, but only until the link expires.
import base64
from hashlib import md5
from time import timesecret = 'secret_key'
path = "/images/1.jpg"
# TTL of URL (in sec)
ttl = 100000
expires = int(time()) + ttl#Token generation
token_hash = md5(f"{expires}{path} {secret}".encode()).digest()
token = base64.b64encode(token_hash).decode().replace("\n", "").replace("+", "-").replace("/", "_").replace("=", "")
secured_url = f"http://cdn.site.com{path}?md5={token}&expires={expires}"# File's URL
print(secured_url)
In these scripts:
The script for creating a secure token that limits the link lifespan and allows access only to an allowlisted IP:
echo -n '2147483647/images/1.jpg1.2.3.4 secret_key' | openssl md5 -binary | openssl base64 | tr +/ -_ | tr -d =
'2147483647/images/1.jpg1.2.3.4 secret_key' = '{expires}{path}{ip} {secret_key}'
The script for creating a secure token that only limits the link lifespan:
echo -n '2147483647/images/1.jpg secret_key' | openssl md5 -binary | openssl base64 | tr +/ -_ | tr -d =
'2147483647/images/1.jpg secret_key' = '{expires}{path} {secret_key}'
In these scripts:
The scripts above can only generate a secure token. You need to create a separate script that will add a secure token and expiry time to links. The script is supposed to create a link as shown below:
Where:
Was this article helpful?
Learn more about our next-gen CDN