Conditions | 6 |
Total Lines | 22 |
Code Lines | 16 |
Lines | 0 |
Ratio | 0 % |
Changes | 0 |
1 | package middlewares |
||
14 | func PhoneAPIKeyAuth(logger telemetry.Logger, tracer telemetry.Tracer, repository repositories.PhoneAPIKeyRepository) fiber.Handler { |
||
15 | logger = logger.WithService("middlewares.APIKeyAuth") |
||
16 | |||
17 | return func(c *fiber.Ctx) error { |
||
18 | ctx, span, ctxLogger := tracer.StartFromFiberCtxWithLogger(c, logger, "middlewares.APIKeyAuth") |
||
19 | defer span.End() |
||
20 | |||
21 | apiKey := c.Get(authHeaderAPIKey) |
||
22 | if len(apiKey) == 0 || apiKey == "undefined" || !strings.HasPrefix(apiKey, "pk_") { |
||
23 | span.AddEvent(fmt.Sprintf("the request header has no [%s] header for the phone key", authHeaderAPIKey)) |
||
24 | return c.Next() |
||
25 | } |
||
26 | |||
27 | authUser, err := repository.LoadAuthContext(ctx, apiKey) |
||
28 | if err != nil { |
||
29 | ctxLogger.Error(stacktrace.Propagate(err, fmt.Sprintf("cannot load user with phone api key [%s]", apiKey))) |
||
30 | return c.Next() |
||
31 | } |
||
32 | |||
33 | c.Locals(ContextKeyAuthUserID, authUser) |
||
34 | ctxLogger.Info(fmt.Sprintf("[%T] set successfully for user with ID [%s]", authUser, authUser.ID)) |
||
35 | return c.Next() |
||
36 | } |
||
38 |