v0.1.0
Licensed under the MIT license
cdn-detector.js
detects whether or not a HTTP response is being served from a Content Delivery Network (CDN),
by inspecting the request's hostname and HTTP response headers.
This project is based on data from:
Releases are available for download from GitHub.
The main source file is src/cdn-detector.js
. There are additional JSON data files in data/*.json
. These
files automatically get converted to .js
files and are merged into the single-file
distribution dist/cdn-detector.[min].js
via gulp
. If you want to use this project in a browser, use one of the dist/*.js
files:
Development: cdn-detector.js - 13.8kb
Production: cdn-detector.min.js - 7.0kb minified, 2.3kb gzipped
cdn-detector.js is also available as the npm cdn-detector module. You can install using Node Package Manager (npm):
npm install cdn-detector
cdn-detector.js is also available via bower. You can install using:
bower install cdn-detector
To include cdn-detector.js
in the browser, include it via a script tag:
<script type="text/javascript" src="cdn-detector.min.js"></script>
Once included in the page, a top-level CdnDetector
object is available on window
. If AMD or CommonJS environments are detected, it will expose itself via those methods.
From the NPM module:
var cdnDetector = require("cdn-detector");
Once loaded, cdn-detector
can be used by calling CdnDetector.detect(hostname, headers)
:
var cdnDetector = require("cdn-detector");
var result = cdnDetector.detect(
"foo.googleusercontent.com", {
"gws": "1",
});
If result
is non-null, the response was served from a CDN:
{
"cdn": "Google",
"evidence": {
"hostname": "\\.googleusercontent\\.com$",
"headers": [
"gws: *"
]
}
}
Determines whether the hostname
and HTTP response headers
indicate that the resource was served via a known CDN.
Arguments:
hostname
: The requested resource's hostname, such asfoo.googleusercontent.com
.headers
: The HTTP response headers in map form, such as{ "Server": "Foo", "Via": "Bar" }
Returns: If no CDN was matched, null
. If a CDN was matched, an object with the CDN name and evidence why:
{
"cdn": "Google",
"evidence": {
"hostname": "\\.googleusercontent\\.com$",
"headers": [
"gws: *"
]
}
}
Determines whether the hostname
indicates that the resource was served via a known CDN.
Arguments:
hostname
: The requested resource's hostname, such asfoo.googleusercontent.com
.
Returns: If no CDN was matched, null
. If a CDN was matched, an object with the CDN name and evidence why. The
evidence is the regex string that matched the hostname.
{
"cdn": "Google",
"evidence": "\\.googleusercontent\\.com$"
}
Determines whether the HTTP response headers
indicate that the resource was served via a known CDN.
Arguments:
headers
: The HTTP response headers in map form, such as{ "Server": "Foo", "Via": "Bar" }
Returns: If no CDN was matched, null
. If a CDN was matched, an object with the CDN name and evidence why. The evidence is an array of HTTP response headers that matched:
{
"cdn": "Google",
"evidence": [
"server: foo"
]
}
The data files for hostnames and headers are in the following files:
data/headers.json
data/hostnames.json
data/multi-headers.json
Via gulp
, these are built as data/*.js
and are included in the dist/*.js
files for use on the web.
In NodeJS, these files are used as-is.
Tests are provided in the test/
directory, and can be run via mocha
:
mocha test/*
Or via gulp
:
gulp test
- v0.1.0 - 2016-08-17: Initial version