2023-10-25 12:09:15 +00:00
|
|
|
package activity
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2023-11-28 15:56:29 +00:00
|
|
|
"strconv"
|
2023-10-25 12:09:15 +00:00
|
|
|
|
2023-11-28 15:56:29 +00:00
|
|
|
"github.com/grpc-ecosystem/grpc-gateway/v2/runtime"
|
2023-10-25 12:09:15 +00:00
|
|
|
"github.com/zitadel/logging"
|
|
|
|
|
|
|
|
"github.com/zitadel/zitadel/internal/api/authz"
|
|
|
|
http_utils "github.com/zitadel/zitadel/internal/api/http"
|
|
|
|
"github.com/zitadel/zitadel/internal/api/info"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
Activity = "activity"
|
2023-11-28 15:56:29 +00:00
|
|
|
|
|
|
|
PathKey = "zitadel-activity-path"
|
|
|
|
RequestMethodKey = "zitadel-activity-request-method"
|
2023-10-25 12:09:15 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type TriggerMethod int
|
|
|
|
|
|
|
|
const (
|
|
|
|
Unspecified TriggerMethod = iota
|
|
|
|
ResourceAPI
|
|
|
|
OIDCAccessToken
|
|
|
|
OIDCRefreshToken
|
|
|
|
SessionAPI
|
|
|
|
SAMLResponse
|
|
|
|
)
|
|
|
|
|
|
|
|
func (t TriggerMethod) String() string {
|
|
|
|
switch t {
|
|
|
|
case Unspecified:
|
|
|
|
return "unspecified"
|
|
|
|
case ResourceAPI:
|
|
|
|
return "resourceAPI"
|
|
|
|
case OIDCRefreshToken:
|
|
|
|
return "refreshToken"
|
|
|
|
case OIDCAccessToken:
|
|
|
|
return "accessToken"
|
|
|
|
case SessionAPI:
|
|
|
|
return "sessionAPI"
|
|
|
|
case SAMLResponse:
|
|
|
|
return "samlResponse"
|
|
|
|
default:
|
|
|
|
return "unknown"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-11-28 15:56:29 +00:00
|
|
|
// Trigger is used to log a specific events for a user (e.g. session or oidc token creation)
|
|
|
|
func Trigger(ctx context.Context, orgID, userID string, trigger TriggerMethod) {
|
2023-10-25 15:10:45 +00:00
|
|
|
ai := info.ActivityInfoFromContext(ctx)
|
|
|
|
triggerLog(
|
|
|
|
authz.GetInstance(ctx).InstanceID(),
|
|
|
|
orgID,
|
|
|
|
userID,
|
|
|
|
http_utils.ComposedOrigin(ctx),
|
|
|
|
trigger,
|
|
|
|
ai.Method,
|
|
|
|
ai.Path,
|
|
|
|
ai.RequestMethod,
|
2023-11-22 10:12:23 +00:00
|
|
|
"",
|
|
|
|
"",
|
2023-10-25 15:10:45 +00:00
|
|
|
authz.GetCtxData(ctx).SystemMemberships != nil,
|
|
|
|
)
|
2023-10-25 12:09:15 +00:00
|
|
|
}
|
|
|
|
|
2023-11-22 10:12:23 +00:00
|
|
|
func TriggerGRPCWithContext(ctx context.Context, trigger TriggerMethod) {
|
2023-10-25 12:09:15 +00:00
|
|
|
ai := info.ActivityInfoFromContext(ctx)
|
2023-10-25 15:10:45 +00:00
|
|
|
triggerLog(
|
|
|
|
authz.GetInstance(ctx).InstanceID(),
|
|
|
|
authz.GetCtxData(ctx).OrgID,
|
|
|
|
authz.GetCtxData(ctx).UserID,
|
|
|
|
http_utils.ComposedOrigin(ctx),
|
|
|
|
trigger,
|
2023-11-28 15:56:29 +00:00
|
|
|
ai.Method,
|
|
|
|
ai.Path,
|
2023-10-25 15:10:45 +00:00
|
|
|
ai.RequestMethod,
|
2023-11-28 15:56:29 +00:00
|
|
|
strconv.Itoa(int(ai.GRPCStatus)),
|
|
|
|
strconv.Itoa(runtime.HTTPStatusFromCode(ai.GRPCStatus)),
|
2023-10-25 15:10:45 +00:00
|
|
|
authz.GetCtxData(ctx).SystemMemberships != nil,
|
|
|
|
)
|
2023-10-25 12:09:15 +00:00
|
|
|
}
|
|
|
|
|
2023-11-28 15:56:29 +00:00
|
|
|
func triggerLog(instanceID, orgID, userID, domain string, trigger TriggerMethod, method, path, requestMethod, grpcStatus, httpStatus string, isSystemUser bool) {
|
2023-10-25 12:09:15 +00:00
|
|
|
logging.WithFields(
|
|
|
|
"instance", instanceID,
|
|
|
|
"org", orgID,
|
|
|
|
"user", userID,
|
|
|
|
"domain", domain,
|
|
|
|
"trigger", trigger.String(),
|
2023-10-25 15:10:45 +00:00
|
|
|
"method", method,
|
|
|
|
"path", path,
|
2023-11-28 15:56:29 +00:00
|
|
|
"grpcStatus", grpcStatus,
|
|
|
|
"httpStatus", httpStatus,
|
2023-10-25 15:10:45 +00:00
|
|
|
"requestMethod", requestMethod,
|
|
|
|
"isSystemUser", isSystemUser,
|
2023-10-25 12:09:15 +00:00
|
|
|
).Info(Activity)
|
|
|
|
}
|