We are constantly improving our product, fixing bugs and introducing features. 
Here you can find the latest updates and changes to Unkey.
 
Our Create Key wizard just got better! Enjoy these new and improved features:
 
Our new API Settings screen is designed for intuitive control over your API configurations. Adjust default bytes, prefixes, and manage security settings seamlessly.
 
verifyKeyThe /v1/keys.verifyKey endpoint has been updated to include a list of roles associated with the key in the verification response, enabling applications to easily determine the user's roles during key verification and make more informed authorization decisions. This simplifies role-based access control implementation and requires one less API request.
We have introduced proper seeding for log pages and metrics, enhancing the ability to generate realistic test data and improving the development and testing experience. You can easily seed a workspace by running pnpm local and selecting Seed Clickhouse/DB. Our CLI will then ask a series of questions about what you would like to seed and how much test data you want.
 
While this isn't a new feature, we've made some updates to our pricing plans to better serve everyone whether you are just starting out or scaling a project.
Larger Free Tier : We've significantly increased our free tier! You now get 150,000 requests per month completely free, up from the original 2,500. This allows you to thoroughly test Unkey and start scaling your project before entering your credit card.
Simplified Pricing : We've streamlined our pricing model to focus solely on requests. We've removed the separate charges for key verifications and standalone rate limit verifications, making it much simpler to understand and predict your costs.
Tiered Pricing : We're introducing tiered pricing starting at just $25. This gives you more flexibility to choose the plan that best fits your needs as you scale, we also reduced the price significantly, below is an example of 10M requests in a month on the new and old pricing:
| Old Price | New Price | 
|---|---|
| $1010.00 | $250.00 | 
We believe these changes will make Unkey an even more attractive and accessible solution for developers of all sizes and allow you to scale without worrying about your bill.
Check out the updated pricing table on our pricing page here.
We have completely revamped our ratelimit and API overview page, making analytics the main focus of the page.
You can see all the important details about a specific namespace, including:
 
You can also override an identifier directly on the page to make blocking or allowing requests more easily.
 
In the API overview, we provide all the important details about a specific API, including:
We also include a natural language search and filter to allow you to quickly analyze and manage your API data.
 
You can also see important details about a specific key, but clicking on the key will open a modal with more information.
 
Our new reques logs are designed to simplify your debugging experience. With comprehensive request filtering, real-time monitoring, and intuitive natural language processing, managing API requests has never been easier.
 
Comprehensive Request Filtering: Now you can view all API requests, including those that encountered errors. Easily filter these requests by status code, method, and path to quickly identify and troubleshoot issues, ensuring a smoother development process.
Natural Language Filtering: Say goodbye to complex, time-consuming filtering! Our new natural language processing feature allows you to filter API requests using simple, conversational phrases. Just type what you’re looking for, and let our system do the rest!
Live Logs for Real-Time Monitoring: Turn on live logs to watch your logs in real time, making it easier to see if your latest deployment is working as expected.
Request IDs for Streamlined Support: Each API request provides you with a request ID. This enhancement simplifies the support process—just share the request ID with our support team, and we can quickly locate and address your concerns.
Standalone Rate Limit Logs: We took everything we built in the request logs and replaced the old rate limit logs, so you can see all the important details in one place, including the timestamp of the request, identifier, status, when the rate limit resets, and more.
 
Migrating Keys Now Accepts an External ID: You can now migrate keys using the external ID ready to be used with our identity product; just pass in the external_id while migrating the key.
Permanent Key Deletion: You can now permanently delete a key. By default, Unkey has the ability to recover a key if requested, but by passing "permanent": true with your deletion request, you can bypass this recovery option.
Default Prefix and Bytes: The API will now use the default bytes and prefix set by the user if they aren't included when creating a key.
We now have an official Python SDK that is developer-friendly & type-safe, making it as easy as possible to start with your favorite language. You can get started right away by installing our package pip install unkey.py
Below is an example of how to create a key using the new SDK:
1import os
2import unkey
3from unkey_py import Unkey
4
5s = Unkey(
6    bearer_auth=os.getenv("UNKEY_BEARER_AUTH", ""),
7)
8
9res = s.keys.create(request={
10    "api_id": "api_123",
11    "name": "my key",
12    "external_id": "team_123",
13    "meta": {
14        "billingTier": "PRO",
15        "trialEnds": "2023-06-16T17:16:37.161Z",
16    },
17    "roles": [
18        "admin",
19        "finance",
20    ],
21    "permissions": [
22        "domains.create_record",
23        "say_hello",
24    ],
25    "expires": 1623869797161,
26    "remaining": 1000,
27    "refill": {
28        "interval": unkey.CreateKeyInterval.DAILY,
29        "amount": 100,
30    },
31    "ratelimit": {
32        "limit": 10,
33        "type": unkey.CreateKeyType.FAST,
34        "duration": 60000,
35    },
36    "enabled": False,
37})
38
39if res.object is not None:
40    # handle response
41    passI want to thank Jonxslays for his community SDK, which allowed developers to get started immediately and provided Unkey with the unkey.py name.
Until today, you had the option to assign an owner to your keys, allowing you to filter keys by a specific owner. This was useful for fetching keys by user or organization via the API, but it didn't provide any additional functionality.
With Identities, you can now group keys together and share metadata and rate limits across them.
For example, we have a company named ACME Corp, which has the enterprise tier and access to our GPT-4o wrapper, with a per-day token limit. So first, we create the identity with the limits:
1curl --request POST \
2  --url https://api.unkey.dev/v1/identities.createIdentity \
3  --header 'Authorization: Bearer unkey_root_key' \
4  --header 'Content-Type: application/json' \
5  --data '{
6  "ratelimits": [
7    {
8      "name": "enterprise_tier",
9      "limit": 50000,
10      "duration": 3600000
11    },
12    {
13      "name": "tokens",
14      "limit": 86400000,
15      "duration": 10
16    }
17  ],
18  "externalId": "acme_corp"
19}'Now we have an identity, we can attach it to one or many keys by referencing the external_id:
1curl --request POST \
2  --url https://api.unkey.dev/v1/keys.createKey \
3  --header 'Authorization: Bearer unkey_root_key' \
4  --header 'Content-Type: application/json' \
5  --data '{
6  "externalId": "acme_corp",
7  "apiId": "api_123",
8  "byteLength": 16
9}'Finally, when we verify a key, we will deny the request if one of the rate limits is exceeded. You can read more about the identity product and use cases in our documentation
A new endpoint has been introduced to allow you to retrieve details about any API key when the key ID is unavailable. Users can send the actual API key to /v1/keys.whoami, which will return the associated data. This is a great way to verify remaining usage, current limits, or identities associated with a key.
1curl --request POST \
2  --url https://api.unkey.dev/v1/keys.whoami \
3  --header 'Authorization: Bearer unkey_root_key' \
4  --header 'Content-Type: application/json' \
5  --data '{"key": "sk_123"}'The API will return details about the key:
1{
2  "id": "key_123",
3  "name": "API Key 1",
4  "remaining": 1000,
5  "identity": {
6    "id": "id_123",
7    "externalId": "ext123"
8  },
9  "meta": {
10    "role": "admin",
11    "plan": "premium"
12  },
13  "createdAt": 1620000000000,
14  "enabled": true,
15  "environment": "production"
16}When we introduced standalone ratelimiting, we included a feature allowing custom overrides without needing to deploy user code. This feature was originally only available via the Unkey dashboard. This month, we introduced the ability to create, update, delete, and list overrides via our API; this unlocks the ability to integrate this into support tooling or back office tools.
1curl --request POST \
2  --url https://api.unkey.dev/v1/ratelimits.setOverride \
3  --header 'Authorization: Bearer unkey-root-key' \
4  --header 'Content-Type: application/json' \
5  --data '{
6    "namespaceName": "email.outbound",
7    "identifier": "user_123",
8    "limit": 10,
9    "duration": 60000,
10    "async": true
11}'You can see how to implement them into your tooling in our API reference.
For the past two weeks, the team has been laser-focused on tackling technical debt, improving our documentation, and crushing UI bugs.

We collaborated with the team at Turso to introduce a new cache-store. This cache store allows using embedded replicas or remote Turso DB. You can read about implementing your cache store in our documentation.
Our documentation has been getting some serious improvements in the past month. First, we introduced a new layout that provides a better way to find what you are looking for based on your use case.
We also introduced new getting started guides that can help you get started with ratelimiting or with identities
We also wrote a new guide on ratelimiting your One Time Passcodes for DDOS and bot protection.
Double-clicking a root key now redirects to settings PR
Optimize all images on our landing page PR
Add flags to pnpm local PR
Removed contentlayer and added content collections PR
Root key details overhaul PR
Create role modal breaks if the permissions name is too long PR
Delete permission modal breaks if the permissions name is too long PR
After Accelerate our first-ever launch week, where we launched products like Toolbox, vault, and LLM caching. We are now working on improving infrastructure, usability, and our docs.
We introduced Authorization into beta at the beginning of the year. This week we introduced them into the API to allow you to create and manage them easily.
You can create a role by passing the name and description, the name can be anything you want it to be, make sure your root key has rbac.*.create_role
1curl --request POST \
2  --url https://api.unkey.dev/v1/permissions.createRole \
3  --header 'Authorization: Bearer <token>' \
4  --header 'Content-Type: application/json' \
5  --data '{
6  "name": "dns.records.manager",
7  "description": "dns.records.manager can read and write dns records for our domains."
8}'You can create a permission by passing the name and description, the name can be anything you want it to be, make sure your root key has rbac.*.create_permission
1curl --request POST \
2  --url https://api.unkey.dev/v1/permissions.createPermission \
3  --header 'Authorization: Bearer <token>' \
4  --header 'Content-Type: application/json' \
5  --data '{
6  "name": "record.write",
7  "description": "record.write can create new dns records for our domains."
8}'You can find the rest of the endpoints for managing roles and permissions in our documentation
You can attach a permission or roles via the API to do this you need to provide the permission or role id to the keys.addPermissions or keys.addRoles.
1curl --request POST \
2  --url https://api.unkey.dev/v1/keys.addPermissions \
3  --header 'Authorization: Bearer <token>' \
4  --header 'Content-Type: application/json' \
5  --data '{
6  "keyId": "<string>",
7  "permissions": [
8    {
9      "id": "<string>"
10    }
11  ]
12}'1curl --request POST \
2  --url https://api.unkey.dev/v1/keys.addRoles \
3  --header 'Authorization: Bearer <token>' \
4  --header 'Content-Type: application/json' \
5  --data '{
6  "keyId": "<string>",
7  "roles": [
8    {
9      "id": "<string>"
10    }
11  ]
12}'You can find the rest of the endpoints for managing roles and permissions on a key our documentation
You still need to attach your permissions to roles or directly to a key via the UI but we will add the endpoints in the coming weeks.
If you are a fan of LLM's and want to use Unkey's Semantic caching when you sign up and create a gateway in a single click. This will allow you to save money and reduce latency for your users.

Fix UI Caching issue when deleting keys Link to PR
Add missing permissions to root keys in the dashboard Link to PR
Filter out deleted keys from permissionsLink to PR
Improved selfhosting docs for the agent link to docs
Reworked the entire layout for easier navigation link to docs
Added Hono quickstart guide link to docs
Updated Next.js quickstart guide link to docs
Updated Bun quickstart guide link to docs
Updated Express quickstart guide link to docs
The Unkey team has been hard at work improving our platform. Here are the latest updates for May 2024.
We have updated our documentation to provide more detailed information on how to use Unkey. Our goal is to make it easier for you to get started and find the information you need. We hope you find the new documentation helpful. If you have any feedback or suggestions, please let us know.
We have dramatically improved our local development experience. With Unkey Local Development, you can now develop and contribute to Unkey without the need for Planetscale and other dependencies. This feature is perfect for developers who want to contribute to Unkey.
Check out our documentation to learn more about Unkey Local Development.
We added a new API endpoint that allows you to migrate your existing keys to Unkey. This allows for zero down time migration and makes it easy to handle large key migrations. You can find more information in our documentation.
We now have official support for Go through out SDK, you can find all the documentation here.
The Unkey team has been hard at work improving our platform. Here are the latest updates for April 2024.
Unkey has a new look! We have updated our website to provide a more modern and hand crafted feel. Our team spent countless hours designing and developing the new site. We hope you enjoy it as much as we do!
With the launch of the new website, we have also moved to a new domain. You can now find us at unkey.com. We always wanted to have a .com domain, and we are excited to finally have it.
We are excited to welcome a new team member to Unkey. Rodz has joined us as a design engineer. He will be working on new features and improving the dashboard to be more user friendly and intuitive.
When you upgrade to the pro plan, you now have unlimited keys. This means you can create as many keys as you need without worrying about hitting a limit. We hope this change makes it easier for you to manage your keys and use Unkey to its full potential.
The Unkey team has been hard at work improving our platform. Here are the latest updates for March 2024.
We are introducing standalone ratelimiting. With this feature, you can rate limit anything while still leveraging the power of Unkey. Our ratelimiting feature works similarly to our keys, providing low global latency and detailed analytics. Moreover, you can configure overrides for specific identifiers, giving you more flexibility.
You can check out a demo that shows our synchronous and asynchronous implementation versus a Redis-based ratelimiter.
This release includes the ability to create and manage roles and permissions, and to assign them to your keys.
We are excited to announce the Alpha release of our Authorization offering. This feature is opt-in and is available to all customers; while it is in Alpha, we advise keeping it to development environments.
When creating roles, we wanted to give you the ability to provide them with an intuitive name and a description. This allows others in your organization to understand the purpose of the role and also gives you the ability to match the systems you have in place.
 
If you have permissions created already, you can assign them to your roles during the creation process. If you don't have permissions created yet, you can create them after creating your role and assign them later.
Our permissions are designed to be flexible; you can create permissions specific to a single API or service, or you can create more general permissions that can be used across multiple roles. We also offer the ability to wild card your permissions for more flexibility.
 
After you have created your permissions, you can assign them to your roles.
Unkey has always focused on making securing your APIs more accessible than ever. With the introduction of our Authorization offering, we wanted to simplify how you can see what roles and permissions are assigned to a key and update them as needed.
 
If you want to understand which roles are using permission, when it was last used, what keys are attached, and when it was last updated, you can do so by clicking on the permission.
 
The team refined our create key UI to provide a better User experience. The new UI offers toggles for enabling features while ensuring you are provided with actionable feedback when there is an error.
 
If you want to learn how to use Neon Postgres and Modal to build, host, and deploy an OpenAI Whisper API - fully secured by Unkey. We collaborated with the team at Neon team to create a tutorial that walks you through the process. You can find the tutorial here.
Command Line Interfaces (CLI) have become integral tools for developers looking to streamline their workflows, but how does CLI authentication work? In our latest blog post, we break down the process of authenticating a CLI tool and how Unkey can help. You can find the blog post here.
The team has been hard at work adding new features and improving the developer experience. We are excited to announce the following features Audit logging, Next.js SDK, Disable Keys, and more.
We are introducing audit logging for the following events to allow for better tracking of changes to your account:

The audit logs are in the dashboard under the Audit logs tab. To access the beta feature, please get in touch with us at support@unkey.dev.
We are introducing a new SDK for Next.js. The SDK is available as a npm package and can be installed with:
1npm install @unkey/nextjsThe Next.js SDK gives you a type-safe way to verify API keys, below is an example of how to use the SDK:
1import { NextRequestWithUnkeyContext, withUnkey } from '@unkey/nextjs';
2
3export const POST = withUnkey(async (req) => {
4
5  // Process the request here
6  // You have access to the verification response using `req.unkey`
7  console.log(req.unkey);
8
9  return new Response('Your API key is valid!');
10});You can now disable a key via the API or in the dashboard. While disabled, the key will act as an invalid key. Suppose you have a customer that has not paid their bill. You may not want to delete the key and wait for the account balance to be current. The key can be disabled temporarily, preventing access until it is enabled.
1curl --request POST \
2  --url https://api.unkey.dev/v1/keys.updateKey \
3  --header 'Authorization: Bearer <token>' \
4  --header 'Content-Type: application/json' \
5  --data '{
6  "enabled": false,
7  "keyId": "<keyId>"
8}'We recently moved our examples into their dedicated repository. We have also added a few new examples.
This example shows how to integrate Unkey and Stripe with an AI application. Below are all the features we included:
Check it out on Github
Adding a CLI to your application is a great way to increase adoption. However, it can be challenging to authenticate users. This example shows you how to use Unkey to authenticate users in your CLI application.
Check it out on Github
The team spent some time removing conflicting type versions and also introducing corepack. Corepack allows us to ensure that when you are contributing, you are using the same version of the dependencies as we are. This should make it easier to contribute to the project.
Happy New Year from the team at Unkey! Firstly, we would like to thank you for your support in 2023; we are excited by the growth and feedback we have received. We are looking forward to 2024 and the new features we have planned.
I spent a lot of time thinking about how we can maximize the value we provide to users of Unkey. We want there to be two things that are true for all users of Unkey:
We have decided to change our pricing model to help us achieve these goals. The free tier has stayed the same, and we will continue to gather feedback. Our pro tier stays the same price at $25 per month, but we are increasing what is included.
The new pro tier is designed to be a better fit for scaling your API authentication. We have increased the number of verifications included by 15x and reduced the cost of additional verifications by half. To put this in perspective, below are the costs of 1 million verifications on the old and new pro tiers.
| Old Pro Tier | New Pro Tier | 
|---|---|
| $223 | $110 | 
This change will make it easier to scale your API authentication with Unkey. If you have any questions or feedback, please reach out to me at james@unkey.dev
When working with limited access APIs, for example, if you sell someone 1000 API calls per month, you need a way to refill the API key each month. In the past, developers created a cron job to refill the key each month. This is a lot of work and can be error-prone.
We have introduced refillable keys to make this process easier. You can now set a refill interval and increment on individual keys, and we take care of refilling a key on its set interval. Currently, we support daily and monthly refills. We will handle daily at midnight UTC and monthly on the first of each month.
Here is an example of creating a key with a daily refill of 100 daily uses.
1curl --request POST \
2  --url https://api.unkey.dev/v1/keys.createKey \
3  --header 'Authorization: Bearer <UNKEY>' \
4  --header 'Content-Type: application/json' \
5  --data '{
6  "apiId":"<API_ID>",
7  "remaining": 100,
8  "refill": {
9      "interval": "daily",
10      "amount": 100
11  }
12}'Dom is joining the Unkey team, bringing us to a total of 4! Dom comes with a wealth of knowledge from his time at Vercel. When we talked to Dom about joining Unkey, he spent a lot of time thinking and talking about how we can make Unkey easier to use and our vision for Unkey. Dom will be working on all aspects of the Unkey stack, and you will see his first project in the coming weeks.
We've been working on improvements to the Unkey dashboard. We also moved the Unkey API to Cloudlfare workers.
Welcome to the Unkey changelog for Decemeber 15th, 2023. The last two weeks have been busy with some core changes to the Unkey product.
Analytics are now more detailed and easier to understand. We added a new chart that shows the number of active keys for your API and allows you to set a timeframe.


Unkey's API has been on Fly.io since we launched in June. We've been reasonably happy with its performance, but we wanted to move to a more reliable and faster platform. We decided to move to Cloudflare Workers, a serverless platform on Cloudflare's edge network. After this change, Unkey's API runs on 300+ data centers worldwide, making it faster and more reliable. You can check out the new API code in our repository to see how we made the changes from Go to Typescript using Hono
Below is a chart of our latency at P95. Can you tell when we moved to CF?

We added a brand new billing page to the dashboard. Previously, you could change your plan and see your current usage. Now, you can see your billing history, change your payment method, and see your current billing cycle. My favorite part is that you can now see a projected forecast of your usage for the month and a projected bill.

With the move to Cloudflare workers, we decided to move to RPC methods. RPC makes it extremely easy to version our API and follow a standard.
Note: We will continue to support the old API for the next few months. We will send out a deprecation notice before we remove the old API.
All our RPC methods are now in the format:
1https://api.unkey.dev/{version}/{service}.{method}Below are a couple of examples of RPC methods: one is a GET request, and the other is a POST request.
1curl "https://api.unkey.dev/v1/keys.getKey?keyId=key_123" \
2  -H "Authorization: Bearer <ROOT_KEY>"1curl -XPOST "https://api.unkey.dev/v1/keys.createKey" \
2  -H "Authorization: Bearer <ROOT_KEY>" \
3  -H "Content-Type: application/json" \
4  -d '{"apiId": "api_123", "name": "My Key"}'UX of UUIDs: Andreas wrote an article on the UX of UUIDs and how some minor tweaks can make a big difference in the user experience.
We've spent the month of November bug-fixing and improving flows.
Welcome to the Unkey changelog. It's been a month since our last changelog, so let's talk about what has changed. We spent the month of November cleaning up bugs and making general improvements to Unkey.
When we announced our hiring and funding, we saw an influx of people wanting to contribute to Unkey. We quickly found out our contribution guide was hard to follow, and we had some third-party requirements that could be optional.
We now have a contribution guide that should take less than 5 minutes to follow and allow you to contribute. You can watch the video I made, which takes you through each area.
We simplified our new user onboarding flow; prior, you'd have to create your workspace. We realized this adds more friction as a workspace is always required. When you sign up for an account, we automatically create the personal workspace.
We have started working on a11y issues across the landing and web application. This will continue on every project, improvement, or change to our website and dashboard.
If you find any, feel free to open an issue on our GitHub, and we will make sure it gets remediated.
Koyeb is a developer-friendly serverless platform to deploy apps globally. Koyeb offers a fully managed environment to deploy any apps in seconds without managing any infrastructure. Koyeb supports any programming languages, frameworks, and tools to build your apps.
This template allows you to use Bun and Unkey and deploy it globally using their platform.
Get started with Koyeb and Unkey today!
We fixed the active key analytics, so you should now see active keys for the current month both in your usage and our dashboard.
There are many more bug fixes, but we couldn't include them all here.
The Unkey team has grown, and we saw insane growth in October.
Welcome to the Unkey changelog. I'm sorry the cadence has been a bit off recently; we've been busy working on some exciting things! You might notice we are including more info about the company in the changelogs. We want to be open and transparent, and this is the perfect place for them. I also traveled to San Francisco to watch the Next.js Conference in person, which was a great experience.
After many late nights and weekends, Andreas is now full-time on Unkey! Andreas will be taking up the role of CTO and will be responsible for the technical direction of Unkey; and has been instrumental in getting us to where we are today. I'm excited to see what we can achieve together!
Mike joined Unkey at the end of October as our first hire. He will be working on the frontend of Unkey as he sharpens his skills and learns the ropes. Mike is an excellent addition to the team and has already fixed several bugs and added some great features!
October was a massive month for Unkey in terms of usage; one of our biggest customers had a great end of the month. To put numbers in perspective, in September, we did 150k verifications through the API system. In October, we did 2.3 million verifications! This is a considerable increase, and we are excited to see what November brings.
On top of having one of the most insane months in terms of usage, we also had a great month in terms of Github stars. We finally cracked the 1000 star mark, a massive milestone for us. Being an open-source company, we love seeing people starring our repo, and we hope to see this number continue to grow.
We have made a number of improvements to our website and web application:
We have done a lot of bug fixes recently, but we have also added two new features:
On our blog, we released three new articles that you might have missed:
At this point, we talked a lot about bug fixes and minor features; now that we are a company with full-time employees, you probably want to know what we are working on next. The Unkey team will be working on introducing permissions to your API keys, giving you fine-grained control over who can access specific routes and what they can do.
The Unkey team worked on improving the analytics we provide. We also introduced templates, to make it easier to get started!
We now have a Unkey templates section on our site! Both Unkey and the community build the templates, making it easier to start. You can find all our current templates at https://unkey.com/templates

If you have created a template or a starter, feel free to create a PR, and we would love to add it to our collection!
We have improved our API analytics. You can now see successful verifications, rate-limited, and usage exceeded for your APIs. Segmentation of successful and unsuccessful requests allows you to have a holistic usage overview and understand your users better than ever!

We will continue to improve our analytical data as time goes on. If you need something for your application, please don't hesitate to contact us!
We just released root key analytics. The root key is the key to the kingdom, and we want to make sure you can understand where it is being used. You can find the root key analytics by selecting details for the specific key.

@unkey/honoWe are introducing @unkey/hono which offers a middleware authentication for Unkey. A minimal setup will read from the Authorization header and the result of the verification will be written to the context and can be access with c.get("unkey")
1import { Hono } from "hono"
2import { UnkeyContext, unkey } from "@unkey/hono";
3
4const app = new Hono<{ Variables: { unkey: UnkeyContext } }>();
5
6app.use("*", unkey());
7
8
9app.get("/somewhere", (c) => {
10  // access the unkey response here to get metadata of the key etc
11  const ... = c.get("unkey")
12
13  return c.text("yo")
14})Check out the docs for all the features https://unkey.com/docs/libraries/ts/hono
Unkey is growing rapidly, and our usage doubled in August and 6X in September. When Unkey started, we knew its potential and the direction it could go. I am excited to begin working full-time on Unkey's overall direction and position.
If you want to chat about how Unkey can solve your API authentication or the plans for the future, feel free to find some time on my calendar: https://cal.com/james-r-perkins/30min
This week, we released a new template and a blog post showing how to issue and associate your API key with a user.
Check out the blog post: Using Unkey with Authentication.
The Unkey team worked on improving the dashboard experience. We want your first impression of Unkey to be as good as the experience when using our API.
You now have a workspace switcher at the top, making tracking which workspace you are currently actively using easier. We also improved the look and feel of the sidebar to make it easier to read and navigate the dashboard.
Our per-key analytics got a significant overhaul, and you can now find details such as when the key was last used, total uses, and usage over the last 30 days. If you use our remaining or expiring features, you can see when it will expire or how many uses are left.
After the chart you are used to, we now have details of each verification attempt, including the resource you requested, User Agent, IP, Region it processed through, and whether it was valid.

You can now update any key directly in the dashboard in the settings section. You can add rate limiting, update metadata, and make a key expire in a few clicks.

APIs are also updatable. You can update the name. If you are an enterprise customer, you can add your whitelisted IPs

We now have an comprehensive account settings section, you can update your personal account, workspace, billing and see your usage.
You can now update your workspace name and upload a new workspace avatar

As a pro-tier subscriber, you can invite and remove your team members as needed. You also have the option to have an admin who can manage accounts and members who can't add or remove other members.

We know it is essential to track usage whether you are on the free plan or running a business, so we introduced a new usage section that shows your active keys and verifications for the current billing cycle.

Finally, you can add a backup or change your primary email address. Upload your avatar and create or update a username.

The documentation has been updated, we shortened the quickstart flow and documented the update key for the Unkey SDK. Look out for our new Next.js wrapper coming soon!
We released a new onboarding experience, improved error messages and fixed bugs!
When you sign up for an Unkey account you now get a new onboarding experience. We take you through creating a workspace, API and showing how Unkey works before you land in the dashboard.
First we ask you to create a workspace, A workspace groups all your resources and billing. You can have one personal workspace for free and create more workspaces with your teammates.

Next we ask you to create an API, an API groups all of your keys together. They are invisible to your users but allow you to filter keys by a namespace. We recommend creating one API for each environment, typically development, preview and production.

Finally we show you how to use Unkey, we show you how to create a root key, how to use it in your application and how to create a regular key.

We think this experience will help new users get up to speed with Unkey and make it easier to get started. Let us know what you think!
We fixed a number of bugs and also improved the dashboard experience here are a list of them:
Have you ever worked with a third party lib, and you received an “Oops try again” error or an extremely vague error that gives you zero indication of what caused it? Great news! Unkey’s error response provide everything you could need to rectify the problem. Every error response will return:
An error code, a link to the documentation, an informative message, and a requestId that you can provide to Unkey support to track down.

Our typescript package @unkey/api got two upgrades this week, to make it even faster to integrate Unkey into your project.
You can now verify a key and make business decisions in just a few lines of code. Below is an example:
1import { verifyKey } from "@unkey/api";
2
3const { result, error } = await verifyKey("key_123");
4
5if (error) {
6  console.error(error.message);
7  return;
8}
9
10if (!result.valid) {
11  // Key isn't valid so don't allow access to resource
12  return;
13}
14
15// process request
16console.log(result);Our SDK will now automatically retry 5 times with a backoff to smooth over network issues, you can of course override the retry and backoff. Below is an example of 10 retries with a backoff
1import { Unkey } from "@unkey/api";
2
3const unkey = new Unkey({
4  token: "<UNKEY_TOKEN>",
5  retry: {
6    attempts: 10,
7    backoff: (previousAttempts) => previousAttempts * 1000, // 0s, 1s, 2s, 3s etc
8  },
9});Huge shoutout to atridadl for creating a starter project using T3, Clerk, Unkey and Drizzle. Check out the link below!
We spent some time fixing bugs and improving performance of Unkey.
We fixed several different bugs in the last two weeks here are the highlights:
We made Unkey easier to self host, we have hidden Kafka and Tinybird behind generic interfaces to provide more flexibility, you can now pass in flags to enable specific providers:
1$ unkey agent --help
2
3Run the Unkey agent
4
5Usage:
6  unkey agent [flags]
7
8Flags:
9      --analytics string   Send analytics to a backend, available: ['tinybird']
10      --enable-axiom       Send logs and traces to axiom
11      --event-bus string   Use a message bus for communication between nodes, available: ['kafka']
12  -h, --help               help for agent
13
14Global Flags:
15  -e, --env string   Path to a .env fileHow Unkey can help AI developers
We just spent the last week making our website, well not just a random one page of ideas we had in the beginning. Unkey makes API management easy, and we wanted our site to reflect that. Our site now has a cohesive feel, and is easy to navigate.
Next up! Our dashboard UI is getting a make over, we might even have a dark mode.
AI is incredible popular, and part of creating your AI product is finding a way to limit a users usage, whether they are paying or you are offering a free trial. Unkey now has usage based invalidation, where you can set how many times a key can be used before we invalidate it. Simply pass in the remaining property with a value and we take care of the rest.
1curl --request POST \
2--url https://api.unkey.dev/v1/keys.createKey \
3--header 'Authorization: Bearer <UNKEY>' \
4--header 'Content-Type: application/json' \
5--data '{
6"apiId":"<API_ID>",
7"remaining": 100
8}'Then when you validate your key we will return two properties, is it valid and how many requests remain.
1curl --request POST \
2--url https://api.unkey.dev/v1/keys.verifyKey \
3--header 'Content-Type: application/json' \
4--data '{
5"key": "<NEW_KEY>"
6}'Which will return if the key is valid, and the remaining value which represents how many verifications are remaining after the current one.
1{
2  "valid": true,
3  "remaining": 99
4}Need to update ratelimits? Change some metadata? Maybe you want to use our new remaining to create tokens and update them when a user pays. This is all now possible with our update endpoint.
1curl --request POST \
2  --url https://api.unkey.dev/v1/keys.updateLey \
3  --header 'Authorization: Bearer <UNKEY>' \
4  --header 'Content-Type: application/json' \
5  -d '{
6    "keyId": "<KEY_ID>",
7    "remaining": 200,
8  }'You can read about this in our documentation.
A huge shoutout to Wilfred Almeida who spent some time creating the Go SDK. You can check out the Go code on GitHub and even help with some remaining items.
You can now work with a team, whitelist your IPs, track usage and much more!
We're excited to bring you our latest changelog for July 10th. Our team and the community has been hard at work adding new features and improving existing ones to enhance your experience with Unkey.
The Whitelist IP feature is an essential security measure that allows you to specify the IP addresses that you want to be able to call Unkey from. This update aims to provide you with an extra layer of security, protecting your data from potential threats.
To use the Whitelist IP feature, you need to be on our Enterprise plan. You can reach out to myself or Andreas in our Discord or via email and we can add the IP range.
We're thrilled to introduce support of teams. This feature allows you to collaborate more effectively with your team members and keeps your personal side projects separate from your work projects.
To create a new team, log into the Unkey admin dashboard, and select create workspace. Once you create your team, you need to upgrade the workspace to the pro tier. Once you have upgraded the workspace you can invite your entire team to Unkey.
We now provide daily usage for both your API and for each individual key. You can use the analytics to find out which of your APIs is being used frequently and which of your users are power users. This is live in your dashboard right now!

Our community this week, has helped us introduce SDKs for three more languages. Huge shoutout to Daniel Roe for introducing a Nuxt module, and the documentation that allows our users to integrate with minimal configuration.
Thanks to Discord user glamboyosa for introducing the Elixir SDK, documentation and example and finally thanks to jonxslays for introducing the Python SDK and documentation.
We truly appreciate the community for adding to Unkey and making the product better and better.
We now prewarm our keys and improved our state-while-revalidate mechanics
Today Andreas focused on rewriting our cache to use stale-while-revalidate mechanics and prewarming when creating new keys.
As a result we now get:
This means more performance for unkey without any extra work for you.
We introduced our new Go powered API that is faster, supports verisioning and more!
Today we finished the complete rewrite of the API in go.
We also introduced pricing, we wanted pricing to be simple and affordable for anyone, so we've created flexible plans that don't need an accounting degree to figure out.
On the free tier:
On the pro tier:
We also offer volume discounts for larger customers, please contact us for more information.
You can check out the pricing page.
Added this very changelog for your eyes, so you can be notified for all our features.
Added this very changelog for your eyes.
If provided, this will only return keys where the ownerId matches.
1curl \
2  --url https://api.unkey.dev/v1/apis/api_123/keys?ownerId=chronark \
3  --header 'Authorization: Bearer <UNKEY>'150,000 requests per month. No CC required.