Skip to main content

Customer Migrations Guide: API Basics

Authentication

Do not share your API key with anyone.

The Kraken data-import REST APIs are authenticated using a token obtained using the ObtainKrakenToken GraphQL Mutation . This can be authenticated with the Organisation API key provided to you by the Kraken Tech team. When you have your token, you can set the Authorization header in the client you are using to make the request. The header should be set to the value of your token. For example, if your token is 12345, you would set the Authorization header to 12345:

curl -H "Authorization: Token 12345" "https://api.octopus.energy/v1/data-import/..."

Optional fields

Some fields in the payload are optional, as specified in the field definitions tables.

  • If a field is optional and you do not wish to provide data for it, then it should be omitted from the payload entirely.

  • If an optional object or array field is provided, the fields within the object/array must be provided if they are required.

  • If an optional field is provided, it must adhere to its relevant validation rules, and the validation rules of any sub-objects in the case of nested fields.

Date and datetime format

Certain endpoints accept dates or datetimes as fields in the payload. These should adhere to the ISO 8601 format.

For example:

YYYY-MM-DD (2023-11-25 - November 25, 2023)

YYYY-MM-DDTHH:MM:SSZ (2023-11-25T08:30:00Z - November 25, 2023, 8:30 AM UTC)

Document path parameters in API endpoints

docs--rest--api-guides--data-import--document-paths--text--html
The APIs here are not responsible for storing files in S3, but instead only provide a reference to the storage location. Speak to the Kraken platform team to find out more about how files can be transferred into S3.

If you are unsure of the path root for your instance of Kraken, please speak to the Kraken team.

Validation errors

Many of the APIs detailed in this guide perform detailed validation on the payloads they receive. If a payload fails validation, the API will return a 400 Bad Request response detailing what went wrong. Here's an example response:

{ "detail": "Could not validate account data.", "code": "account_failed_validation", "errors": [ { "detail": "abcde is not a valid phone number", "code": "invalid_phone_number", "attr": "customers.0.landline" } ] }

Each item in the errors array corresponds to an error object with the same three keys:

  • detail is a human-readable description of the error. The exact wording may change over time, so please don't parse it or build any logic around it.
  • code is a machine-readable identifier for the error type. It will not change over time, so feel free to use in data analytics or other logic.
  • attr is a dot-delimited path that specifies which part of the input data caused the error. String components of the path refer to the names of fields within an object, while numeric components refer to the index of an item within an array, with 0 representing the first item in the array.

API compatibility

This API will evolve over time. Future updates to the API may include new endpoints or additions to existing endpoints. In order to preserve backward compatibility, the behaviour and return values of existing endpoints will not change without notice. The exception to this is fields that are currently undocumented, which may be given specific meaning in the future. Care should be taken when constructing payloads and requests to ensure that only documented fields are included.

Import Supplier

The import supplier is used to group migrated accounts, allowing for the configuration of specific behaviours during account migration, such as sending automated customer emails upon migration. We will set up an initial import supplier for you and together determine your desired configuration.

Additional import suppliers for specific customer cohorts may also be created, addressing unique needs like migrating long-standing debt customers without initial communications. If you think you might need another import supplier, have a chat with us and we’ll assess whether it's the best solution.


In each payload you must populate the import_supplier field with the appropriate import supplier code.

An import supplier has one of the following statuses. The status is set by the Kraken team.

StatusDescription
OngoingThe import supplier is currently in use and is accepting new accounts for migration.
PausedMigrations using this import supplier are paused. Accounts attempting to migrate while in this status will receive an error. The difference between this status and the complete status is mostly semantic. Paused means we expect more accounts to be migrated on this import supplier.
CompleteMigrations using this import supplier are complete. Accounts attempting to migrate while in this status will receive an error. The difference between this status and the paused status is mostly semantic. Complete means we do not expect any more accounts to be migrated on this import supplier.