Exemple #1
0
        public async Task Invoke(HttpContext context, ISecretManager secretManager)
        {
            // Validate Authentication header only on /api/...
            if (!context.Request.Path.StartsWithSegments("/api"))
            {
                await _next.Invoke(context);

                return;
            }

            if (!context.Request.Headers.Keys.Contains(SDK.Net.Constants.AuthorizationHeader))
            {
                context.Response.StatusCode = 401;
                return;
            }

            var authorizationValues = context.Request
                                      .Headers[Constants.AuthorizationHeader]
                                      .ToString()
                                      .Split(new string[] { " " }, StringSplitOptions.RemoveEmptyEntries);

            if (authorizationValues.Length < 2 ||
                !string.Equals(authorizationValues[0], Constants.AuthorizationMethodSlamby, StringComparison.OrdinalIgnoreCase) ||
                !secretManager.IsMatch(authorizationValues[1]))
            {
                context.Response.StatusCode = 401;
                return;
            }

            await _next.Invoke(context);
        }