-
Notifications
You must be signed in to change notification settings - Fork 25k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Metadata for API keys #48182
Comments
Pinging @elastic/es-security (:Security/Authentication) |
@arisonl @roncohen @tvernum as we discussed in previous conversations, this could be a very turning point to simplify the authentication and authorization flow for Ingest, where we actually use a separate service. I'd like to keep it very generic, so that Elasticsearch has no knowledge of the metadata content, and it can be used in very different scenarios. This is probably the only requirement on the Elasticsearch side to make API keys suitable for Ingest needs, but I'll continue to investigate about that. |
+1. This is needed for elastic/kibana#77966 (currently blocked until we can do something like that). Use case |
I would have expected that all of those API keys would be owned by the same user ( |
Jumping in as @sqren is on vacation right now. Can you clarify whether the question is; are all API keys owned by a single user? Following on, if they were, would that user only have API keys used for agent/server auth? Currently, API keys used for this purpose are not owned by a single user, they're not even created via kibana at the moment (see elastic/kibana#77966 for details). |
Shouldn't they be owned by a single user? Do you intentionally want APM API Keys to be owned and managed by individuals? |
Right now there is no UI for creating API keys, non-cloud users can use a CLI tool built into the APM Server, cloud users need to follow the docs for creating the API key manually. |
Did we reach a decision here?
As mentioned above this is not the case.
As I understand, when creating an API key via Kibana the request can either be made as the end user (in which case the API key will be owned by this user) or by the internal user (the shared kibana user). I'm fine with letting individuals own/manage api keys unless there is a better approach. |
Not yet. I don't think generic metadata is what you need in order to solve the attribution problem you have. I think we need something more specific around the owning "application" and potentially a reference id. Which isn't to say that we won't add generic metadata, I just don't think it's helpful to solve common problems like this in ad-hoc ways via metadata.
The current design for API keys treats them as secondary, restricted, credentials for the owning user. For example, it an action is performed by an API key, the audit logs will record it as having been taken by the user that created the API key. Likewise, the I don't think that's what you want. We don't currently have a mechanism for users creating API keys for use in/by other services. Our expectation was that in situations like this the API keys would be owned by whatever user APM server uses to write to Elasticsearch - that APM itself would own whatever API keys it needed. |
Correct, this doesn't sound great.
Okay, that makes sense. I'll sync with the rest of the team and we'll figure out what we want to do in the near future. |
I agree. I've opened #67390 as an alternative proposal. |
We have done some scoping and design on this feature and I'd like to share the current plan: NOTE: Metadata on API keys are Not secret. Users who have access to view API keys (e.g.
Here are some examples of what the APIs would look like after the proposed changes:
PUT _security/api_key
{
"name": "key-1",
"role_descriptors": {
"agent": {
"indices": [
{
"names": [
"index"
],
"privileges": [
"create_doc"
]
}
]
}
},
"metadata": {
"application": "fleet-agent",
"host-tag": "foo",
"codes": [
3,
5,
7,
9
],
"environment": {
"os": "Linux",
"level": "untrusted",
"rating": 3
}
}
} The response will be the same as what we currently have: {
"id": "Nm_y63cBLN0wxfKLwdEc",
"name": "key-1",
"api_key": "Mw7-sm8mTLWzk-XvKNiBWw"
}
{
"api_keys": [
{
"id": "MG_c63cBLN0wxfKLA9Ht",
"name": "key-1",
"creation": 1614569800692,
"invalidated": false,
"username": "elastic-admin",
"realm": "file1",
"metadata": {
"host-tag": "foo",
"codes": [
3,
5,
7,
9
],
"environment": {
"os": "Linux",
"level": "untrusted",
"rating": 3
},
"application": "fleet-agent"
}
},
{
"id": "Mm_g63cBLN0wxfKLMNGv",
"name": "key-3",
"creation": 1614570074288,
"invalidated": false,
"username": "elastic-admin",
"realm": "file1",
"metadata": {}
}
]
} |
Not stated explicitly, but there will be no method for updating metadata as part of this plan, correct? Does the comment in #48182 (comment):
still stand in regards to finding api keys created for an application. Put another way, can we close #67390 now and expect to use the future search capabilities on metadata for this purpose? |
Good catch! No it will not be updatable. I will add this to the plan to make it explicit. Generally we feel mutable API key is a broader topic that we'd like to tackle in a whole instead for just metadata.
I think it could still be an issue for APM's particular use case. Metadata key/value cannot be reserved for any clients, i.e. anyone can write any metadata as will as long as they can create an API key. This means, the metadata |
It's not mentioned in @ywangd's original summary above, but we've discussed this elsewhere - one of the design choices we're proposing is that there will not be any security controls around setting metadata. That is, if you can create an API key then you can set any metadata you want on it. Consequently, searching across all API keys in a cluster with So, performing that search on API keys that were created by a user that you control would be reasonable. Performing that search in a cluster that is locked down to only be accessible by trusted users (e.g. the security cluster in ECE) is also reasonable. But searching across all creators on an arbitrary cluster where any number of users have the Whether that risk is acceptable depends on what you want to do with that list. If it's just shown in a UI then maybe it's OK, but it definitely not ideal and it's not a good option in general. |
@ywangd I'm not sure to get what you mean with secret. Seems like the opposite to me, as anybody that can manage API keys can also see them. |
🤦 🤦 I missed the critical word here. It should have been "not secret". I updated the original comments. Thanks for catching it. |
Now that the initial support is in where should we track the additional work for this effort? We're primarily interested in searching metadata for elastic/kibana#77966. |
@graphaelli I created following two more issues to track feature work on API key metadata
Also note that the backport (#70956) for API key metadata is currently on hold and waiting for an agreed change on the system indices (@jaymode). We are still targeting for 7.13. But you may need test it against the master branch for the time being. |
This PR adds the missing doc update to the grant api key rest api page for the new API key metadata field added by elastic#70292 Relates: elastic#48182
This PR adds the missing doc update to the grant api key rest api page for the new API key metadata field added by elastic#70292 Relates: elastic#48182
This PR adds the missing doc update to the grant api key rest api page for the new API key metadata field added by #70292 Relates: #48182 Co-authored-by: Yang Wang <[email protected]>
Description
We are considering to extend Elasticsearch API keys in order to support internal requirements by other teams, and avoid building new features that would increase complexity and maintenance costs.
The current implementation is a good starting point, but hits its limits in complex scenarios where those keys are used in a more sophisticated authentication flow.
At the moment, the solution is to build an external logic around keys, or reimplement an independent similar feature.
Proposal
One thing that could be very useful is to allow custom arbitrary metadata to be attached to an API key during the creation action. This is totally transparent to Elasticsearch, that has no knowledge of the meaning (and format) of the metadata, and doesn't perform any action on it.
An example of metadata could be the scope of the key, a description, or a cryptographic signature.
This implies that metadata can be passed to the Create API key call, stored as an attribute of the newly generated key, and then returned by the Get API key.
Each user can define the metadata, and build some logic around it.
Related Kibana issue: elastic/kibana#93820
The text was updated successfully, but these errors were encountered: