Legacy: Tyk Classic PortalYou’re viewing documentation for the Tyk Classic Portal, which is no longer actively maintained.If you’re looking for the latest API documentation for the new Tyk Developer Portal, please refer to the
Postman collection or visit the
Tyk Developer Portal section.The Classic Portal is in maintenance mode and will be deprecated soon. For questions or support, contact us at
support@tyk.io.
This functionality is available from v2.3.8
Why Build a Custom Developer Portal?
The Tyk Dashboard includes portal functionality by default, but in some cases it is required to use custom logic or, for example, embed the portal into an existing platform. Thankfully Tyk is flexible enough to provide an easy way of integrating the portal to any platform and language using a few API calls. The source code is available from the following GitHub repo - https://github.com/TykTechnologies/tyk-custom-portal A video covering the process of building a custom portal is available to view here:Building Blocks
Before starting work on implementing a custom developer portal, let’s understand the basic building blocks.Obtaining a Dashboard API Key
To run queries against the Tyk Dashboard API you need to obtain credentials from the Users screen.- Select Users from the System Management section.
- In the Users list, click Edit for your user.
- The API key is the Tyk Dashboard API Access Credentials, copy this somewhere you can refer to it.
API Key Location
Let’s save it to the environment variable to simplify code examples in this guide. All the commands should be run in your terminal.Don’t forget to replace TYK_API_KEY=1efdefd6c93046bc4102f7bf77f17f4e with your own value
Creating a Developer
Request
Response
Message contains the developer internal ID., You do not have to remember it, since you can find a developer by his email, using the API.
Developer by Email
Request
Response
Developer Validation
By default, the Tyk Developer portal automatically accepts all developer registrations, if they are not completely disabled in the portal configuration.Do not confuse developer registration with key access, if they are registered to the portal, it does not mean they automatically have access to your APIs.
inactive attribute to handle it. By default, it is false, and you can set it to true if additional verification is needed. To make this work, you need to add additional logic to your custom portal code.
Updating a Developer. Example: Adding Custom Fields
Let’s say we want to add new custom “field” to the developer, to store some internal meta information. Tyk so far does not support PATCH semantics, e.g. you cannot update only single field, you need to provide the full modified record. Lets created an updated developer record, based on the example response provided in Developer by Email section. Let’s add new “traffic_source” custom field.Request
Response
Login Workflow: Checking User Credentials
If you need to implement own login workflow, you need be able to validate user password.Request
Listing Available APIs
Inside the admin dashboard in the portal menu, you can define catalogs with the list of APIs available to developers. Each defined API is identified by its policy id field.Request
Response
Issuing Keys
To generate a key for the developer, first he should send a request to the administrator of the API, and if needed provide details of the key usage. By default, all keys requests are approved automatically, and the user immediately receives his API key, but you can turn on the Review all key requests before approving them option in the portal settings, to add additional verification step, and approve all keys manually. Once a key is issued, the user receives an email with the key details.Request
Response
Checking User Subscriptions and Keys
The Developer object contains thesubscriptions field with information about user API keys, and associtated API’s (policies). For Example:
Request
Analytics
You can get aggregate statistics for 1 key or all developer keys (need to specify a list of all keys). Also, you can group by day (hour or month), and by API (policy id). API Endpoint:/api/activity/keys/aggregate/#{keys}/#{from}/#{to}?p=-1&res=day
- keysshould be specified separated by ’,’ delimiter.
- fromand- tovalues must be in // format.
- resolution specified resattribute: ‘day’, ‘hour’ or ‘month’
- api_id- policy id associated with developer portal API. If ommited return stats for all APIs.
Request
Response
add2b342,5f1d9603, is 2 users keys. Note that this example shows hashed key values as described here. Key hashing is turned on for the Cloud, but for Multi-Cloud and Self-Managed installations you can also turn it off. Hashed keys mean that the API administrator does not have access to real user keys, but they can still use the hashed values for showing analytics.
Building a Portal
This guide includes the implementation of a full featured developer portal written in Ruby in just 250 lines of code. This portal implementation does not utilize any database and uses our Tyk Dashboard API to store and fetch all the data. To run it, you need to have Ruby 2.3+ (latest version). Older versions may work but have not been tested. First, you need to install dependencies by runninggem install sinatra excon --no-ri in your terminal.
Then run it like this: TYK_PORTAL_PORT=8080 TYK_API_KEY=<your-api-key-here> ruby portal.rb
You can also specify the TYK_DASHBOARD_URL if you are trying this portal with an Self-Managed installation. By default, it is configured to work with Cloud or Multi-Cloud.