| 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 |