-
Notifications
You must be signed in to change notification settings - Fork 16
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
Explore machine reachable approach to event definitions #158
Comments
Here's an example of the CAEP Session Revoked event, defined in JSON Schema. This only includes the properties of the event object (e.g. "https://schemas.openid.net/secevent/caep/event-type/session-revoked/": { < this > }. {
"$schema": "https://json-schema.org/draft/2020-12/schema",
"$id": "https://schemas.openid.net/secevent/caep/event-type/session-revoked/v1.schema.json",
"title": "Session Revoked",
"description": "Session Revoked signals that the session identified by the subject has been revoked. The explicit session identifier may be directly referenced in the subject or other properties of the session may be included to allow the receiver to identify applicable sessions.",
"type": "object",
"properties": {
"initiating_entity": {
"description": "Describes the entity that invoked the event.",
"type": "string",
"oneOf": [
{
"const": "admin",
"description": "an administrative action triggered the event"
},
{
"const": "user",
"description": "an end-user action triggered the event"
},
{
"const": "policy",
"description": "a policy evaluation triggered the event"
},
{
"const": "system",
"description": "a system or platform assertion triggered the event"
}
]
},
"reason_admin": {
"description": "a localizable administrative message intended for logging and auditing. The object MUST contain one or more key/value pairs, with a BCP47 [RFC5646] language tag as the key and the locale-specific administrative message as the value.",
"type": "object"
},
"reason_user": {
"description": "a localizable user-friendly message for display to an end-user. The object MUST contain one or more key/value pairs, with a BCP47 [RFC5646] language tag as the key and the locale-specific end-user message as the value.",
"type": "object"
},
"event_timestamp": {
"description": "the time at which the event described by this SET occurred. Its value is a JSON number representing the number of seconds from 1970-01-01T0:0:0Z as measured in UTC until the date/time. This value MUST represent the time at which the session revocation occurred",
"type": "number"
}
}
} I think this could work. One question is whether the schema should contain the entire SET (including |
I feel strongly that we should not include the entire SET in the definition. Just the event itself. Since the |
A few comments / observations:
|
From 2024-05-28 in person discussion:
|
Notes from the call on 11/19:
|
We've long discussed the challenges with the event specs, which are effectively just dictionaries, being formal specifications that go through full OIDF process. This can make it challenging to add new events quickly which can make the effort feel less accessible.
This issue is to track and explore a more machine readable approach to defining events, such as using a JSON schema file mainted on GitHub with version controls.
Some early thoughts:
The text was updated successfully, but these errors were encountered: