Access and authentication
Website personalisation: Headless API integration
All connections to the Query API must be authenticated using:
- keys and secrets
- IP restrictions
- properly formatted requests
Note
Ometria only supports requests made using SSL (version v1.2 or higher).
1. Authentication method
There are two methods for protecting the query endpoints:
You'll need to implement one of these methods to access your Query API endpoint.
If no method is implemented you can't access the Query API endpoint.
Basic authentication
To enable basic authentication, log into Ometria and go to: Website Personalisation > Administration > Settings > Query API Access
data:image/s3,"s3://crabby-images/c81c8/c81c82bed68174f415662adba8927e045ea08b38" alt=""
Toggle on Basic Authentication:
data:image/s3,"s3://crabby-images/08db1/08db1e9e5756b0f86a4cd2e2019d2b6adb503e82" alt=""
IP Restriction
To enable IP restriction, log into Ometria and go to: Website Personalisation > Administration > Settings > Query API Access
data:image/s3,"s3://crabby-images/64f02/64f02f0a47df906c30f41e84f9583cf670bc3d20" alt=""
Select IP Restriction and enter your IP address:
data:image/s3,"s3://crabby-images/c341e/c341ef5c2a4057bc810b8a10e78c0e06a919a431" alt=""
2. Create an API key and secret combination
To create an API key for website personalisation, go to: Website Personalisation > Administration > Settings > Query API Access
data:image/s3,"s3://crabby-images/83f38/83f38208b5b6bfb05265bd0db331a3437c8df52a" alt=""
Note
This is a different path than Ometria's usual API key screen.
Select Add API Key:
data:image/s3,"s3://crabby-images/9a393/9a393c400d08052cd743b6ff4f44b8ca7f734bd3" alt=""
You can create as many key-secret pairs as you need.
3. Construct request header
If you're using basic authentication then you'll need to construct a header using your authentication credentials.
Here's how:
- Combine your username (API key) and password (API secret) with a single colon (:).
- Base64 encode the combined string.
- Prepend "Basic" and a space to the result.
Example:
For a key f4198aa7934b402981179610e71dcdbe and a secret of AW328UXvlwqfsOkS8smjIGtxfXAqjJxD.
const key = "f4198aa7934b402981179610e71dcdbe";
const secret = "AW328UXvlwqfsOkS8smjIGtxfXAqjJxD";
const encoded = btoa(`${key}:${secret}`);
// encoded output ZjQxOThhYTc5MzRiNDAyOTgxMTc5NjEwZTcxZGNkYmU6QVczMjhVWHZsd3Fmc09rUzhzbWpJR3R4ZlhBcWpKeEQ=
4. Make a request
Here's an example request using the previously encoded key and secret:
POST "https://{{domainkey}}.store-{{locationkey}}.ometria.services/api/query"
--header "Authorization: Basic ZjQxOThhYTc5MzRiNDAyOTgxMTc5NjEwZTcxZGNkYmU6QVczMjhVWHZsd3Fmc09rUzhzbWpJR3R4ZlhBcWpKeEQ="
Updated 2 days ago