Exemple #1
0
 public void Init(IQueueClient queueClient,
                  IMessageProcessorFactory messageProcessorFactory,
                  ConfigurationEntry configuration)
 {
     Configuration            = configuration;
     _queueClient             = queueClient;
     _messageProcessorFactory = messageProcessorFactory;
 }
        public void ProcessMessage(string message, ConfigurationEntry configurationEntry)
        {
            Logger.Trace($"Preparing post to {configurationEntry.RedriveUrl}");
            var uri    = new Uri(configurationEntry.RedriveUrl);
            var client = new RestClient($"{uri.Scheme}://{uri.Host}:{uri.Port}");
            var post   = new RestRequest(uri.PathAndQuery, configurationEntry.UsePUT ? Method.PUT : Method.POST);

            post.AddParameter("application/json", message, ParameterType.RequestBody);

            if (!string.IsNullOrEmpty(configurationEntry.AwsGatewayToken))
            {
                post.AddHeader("x-api-key", configurationEntry.AwsGatewayToken);
            }

            if (!string.IsNullOrEmpty(configurationEntry.AuthToken))
            {
                post.AddHeader("Authorization", configurationEntry.AuthToken);
            }

            if (!string.IsNullOrEmpty(configurationEntry.BasicAuthPassword) &&
                !string.IsNullOrEmpty(configurationEntry.BasicAuthUserName))
            {
                client.Authenticator = new HttpBasicAuthenticator(configurationEntry.BasicAuthUserName,
                                                                  configurationEntry.BasicAuthPassword);
            }

            if (configurationEntry.IgnoreCertificateErrors)
            {
                client.RemoteCertificateValidationCallback = (sender, certificate, chain, sslPolicyErrors) => true;
            }

            if (configurationEntry.Timeout.HasValue)
            {
                client.Timeout = configurationEntry.Timeout.Value;
            }

            Logger.Trace($"Posting to {configurationEntry.RedriveUrl}");
            var response = client.Execute(post);

            if (response.IsSuccessful &&
                (response.StatusCode == HttpStatusCode.OK || response.StatusCode == HttpStatusCode.Created))
            {
                Logger.Trace($"Post to {configurationEntry.RedriveUrl} successful");
                return;
            }

            Logger.Trace($"Post to {configurationEntry.RedriveUrl} failed (status code [{response.StatusCode}], error [{response.ErrorMessage}])");
            if (response.ErrorException != null)
            {
                throw response.ErrorException;
            }

            throw new InvalidOperationException($"Received {response.StatusCode} status code with content [{response.Content}]");
        }