Ver a proveniência

cleanup code.

master
yangxiaodong há 7 anos
ascendente
cometimento
819c4465ae
45 ficheiros alterados com 123 adições e 166 eliminações
  1. +1
    -3
      src/DotNetCore.CAP.EntityFrameworkCore/CAP.EFOptions.cs
  2. +1
    -1
      src/DotNetCore.CAP.EntityFrameworkCore/CAP.SqlServerCapOptionsExtension.cs
  3. +2
    -8
      src/DotNetCore.CAP.EntityFrameworkCore/CAP.SqlServerOptions.cs
  4. +1
    -1
      src/DotNetCore.CAP.EntityFrameworkCore/CapPublisher.cs
  5. +2
    -5
      src/DotNetCore.CAP.EntityFrameworkCore/FetchedMessage.cs
  6. +3
    -6
      src/DotNetCore.CAP.EntityFrameworkCore/IAdditionalProcessor.Default.cs
  7. +1
    -4
      src/DotNetCore.CAP.EntityFrameworkCore/SqlServerFetchedMessage.cs
  8. +3
    -4
      src/DotNetCore.CAP.EntityFrameworkCore/SqlServerStorage.cs
  9. +1
    -1
      src/DotNetCore.CAP.Kafka/CAP.KafkaCapOptionsExtension.cs
  10. +2
    -2
      src/DotNetCore.CAP.Kafka/CAP.KafkaOptions.cs
  11. +0
    -1
      src/DotNetCore.CAP.Kafka/CAP.Options.Extensions.cs
  12. +0
    -1
      src/DotNetCore.CAP.Kafka/KafkaConsumerClient.cs
  13. +1
    -1
      src/DotNetCore.CAP.Kafka/PublishQueueExecutor.cs
  14. +1
    -1
      src/DotNetCore.CAP.RabbitMQ/CAP.RabbiMQOptions.cs
  15. +1
    -1
      src/DotNetCore.CAP.RabbitMQ/CAP.RabbitMQCapOptionsExtension.cs
  16. +0
    -1
      src/DotNetCore.CAP.RabbitMQ/CapSubscribeAttribute.cs
  17. +1
    -2
      src/DotNetCore.CAP.RabbitMQ/PublishQueueExecutor.cs
  18. +1
    -1
      src/DotNetCore.CAP/Abstractions/ModelBinding/IModelBinder.cs
  19. +0
    -1
      src/DotNetCore.CAP/CAP.Options.cs
  20. +2
    -2
      src/DotNetCore.CAP/CAP.ServiceCollectionExtensions.cs
  21. +1
    -1
      src/DotNetCore.CAP/ICapOptionsExtension.cs
  22. +2
    -3
      src/DotNetCore.CAP/ICapPublisher.cs
  23. +0
    -1
      src/DotNetCore.CAP/IConsumerHandler.Default.cs
  24. +2
    -5
      src/DotNetCore.CAP/IQueueExecutor.cs
  25. +11
    -11
      src/DotNetCore.CAP/IStorage.cs
  26. +9
    -9
      src/DotNetCore.CAP/IStorageTransaction.cs
  27. +1
    -1
      src/DotNetCore.CAP/Infrastructure/Helper.cs
  28. +2
    -6
      src/DotNetCore.CAP/Infrastructure/StatusName.cs
  29. +1
    -1
      src/DotNetCore.CAP/Infrastructure/WaitHandleEx.cs
  30. +0
    -1
      src/DotNetCore.CAP/Internal/IConsumerServiceSelector.Default.cs
  31. +2
    -2
      src/DotNetCore.CAP/Internal/MethodMatcherCache.cs
  32. +3
    -3
      src/DotNetCore.CAP/Internal/ObjectMethodExecutor.cs
  33. +10
    -4
      src/DotNetCore.CAP/Internal/SubscriberNotFoundException.cs
  34. +0
    -7
      src/DotNetCore.CAP/LoggerExtensions.cs
  35. +2
    -2
      src/DotNetCore.CAP/Models/CapPublishedMessage.cs
  36. +1
    -1
      src/DotNetCore.CAP/Models/CapQueue.cs
  37. +1
    -1
      src/DotNetCore.CAP/Models/MessageType.cs
  38. +2
    -2
      src/DotNetCore.CAP/OperateResult.cs
  39. +2
    -7
      src/DotNetCore.CAP/Processor/IAdditionalProcessor.cs
  40. +1
    -1
      src/DotNetCore.CAP/Processor/IDispatcher.Default.cs
  41. +2
    -6
      src/DotNetCore.CAP/Processor/IDispatcher.cs
  42. +38
    -38
      src/DotNetCore.CAP/Processor/IProcessor.PublishQueuer.cs
  43. +2
    -2
      src/DotNetCore.CAP/Processor/IProcessor.SubscribeQueuer.cs
  44. +1
    -1
      src/DotNetCore.CAP/Processor/RetryBehavior.cs
  45. +3
    -3
      src/DotNetCore.CAP/QueueExecutorFactory.cs

+ 1
- 3
src/DotNetCore.CAP.EntityFrameworkCore/CAP.EFOptions.cs Ver ficheiro

@@ -1,6 +1,4 @@
using System;
using System.Collections.Generic;
using System.Text;

namespace DotNetCore.CAP
{
@@ -29,4 +27,4 @@ namespace DotNetCore.CAP

public Type DbContextType { get; internal set; }
}
}
}

+ 1
- 1
src/DotNetCore.CAP.EntityFrameworkCore/CAP.SqlServerCapOptionsExtension.cs Ver ficheiro

@@ -28,4 +28,4 @@ namespace DotNetCore.CAP
services.AddSingleton(sqlServerOptions);
}
}
}
}

+ 2
- 8
src/DotNetCore.CAP.EntityFrameworkCore/CAP.SqlServerOptions.cs Ver ficheiro

@@ -1,9 +1,4 @@
using System;
using System.Collections.Generic;
using System.Text;
using DotNetCore.CAP.EntityFrameworkCore;

namespace DotNetCore.CAP
namespace DotNetCore.CAP
{
public class SqlServerOptions : EFOptions
{
@@ -11,6 +6,5 @@ namespace DotNetCore.CAP
/// Gets or sets the database's connection string that will be used to store database entities.
/// </summary>
public string ConnectionString { get; set; } //= "Server=DESKTOP-M9R8T31;Initial Catalog=Test;User Id=sa;Password=P@ssw0rd;MultipleActiveResultSets=True";

}
}
}

+ 1
- 1
src/DotNetCore.CAP.EntityFrameworkCore/CapPublisher.cs Ver ficheiro

@@ -93,4 +93,4 @@ namespace DotNetCore.CAP.EntityFrameworkCore
PublishQueuer.PulseEvent.Set();
}
}
}
}

+ 2
- 5
src/DotNetCore.CAP.EntityFrameworkCore/FetchedMessage.cs Ver ficheiro

@@ -1,7 +1,4 @@
using System;
using System.Collections.Generic;
using System.Text;
using DotNetCore.CAP.Models;
using DotNetCore.CAP.Models;

namespace DotNetCore.CAP.EntityFrameworkCore
{
@@ -11,4 +8,4 @@ namespace DotNetCore.CAP.EntityFrameworkCore

public MessageType MessageType { get; set; }
}
}
}

+ 3
- 6
src/DotNetCore.CAP.EntityFrameworkCore/IAdditionalProcessor.Default.cs Ver ficheiro

@@ -1,11 +1,8 @@
using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Text;
using System.Threading.Tasks;
using Dapper;
using DotNetCore.CAP.Processor;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;

namespace DotNetCore.CAP.EntityFrameworkCore
@@ -44,14 +41,14 @@ namespace DotNetCore.CAP.EntityFrameworkCore
var removedCount = 0;
do
{
using(var connection = new SqlConnection(_options.ConnectionString))
using (var connection = new SqlConnection(_options.ConnectionString))
{
removedCount = await connection.ExecuteAsync($@"
DELETE TOP (@count)
FROM [{_options.Schema}].[{table}] WITH (readpast)
WHERE ExpiresAt < @now;", new { now = DateTime.Now, count = MaxBatch });
}
if (removedCount != 0)
{
await context.WaitAsync(_delay);
@@ -63,4 +60,4 @@ WHERE ExpiresAt < @now;", new { now = DateTime.Now, count = MaxBatch });
await context.WaitAsync(_waitingInterval);
}
}
}
}

+ 1
- 4
src/DotNetCore.CAP.EntityFrameworkCore/SqlServerFetchedMessage.cs Ver ficheiro

@@ -1,11 +1,8 @@
using System;
using System.Collections.Generic;
using System.Data;
using System.Text;
using System.Threading;
using Dapper;
using DotNetCore.CAP.Models;
using Microsoft.EntityFrameworkCore.Storage;

namespace DotNetCore.CAP.EntityFrameworkCore
{
@@ -73,4 +70,4 @@ namespace DotNetCore.CAP.EntityFrameworkCore
}
}
}
}
}

+ 3
- 4
src/DotNetCore.CAP.EntityFrameworkCore/SqlServerStorage.cs Ver ficheiro

@@ -43,7 +43,6 @@ namespace DotNetCore.CAP.EntityFrameworkCore

protected virtual string CreateDbTablesScript(string schema)
{

var batchSQL =
$@"
IF NOT EXISTS (SELECT * FROM sys.schemas WHERE name = '{schema}')
@@ -72,7 +71,7 @@ CREATE TABLE [{schema}].[Received](
[Added] [datetime2](7) NOT NULL,
[ExpiresAt] [datetime2](7) NULL,
[StatusName] [nvarchar](50) NOT NULL,
CONSTRAINT [PK_{schema}.Received] PRIMARY KEY CLUSTERED
CONSTRAINT [PK_{schema}.Received] PRIMARY KEY CLUSTERED
(
[Id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
@@ -90,7 +89,7 @@ CREATE TABLE [{schema}].[Published](
[Added] [datetime2](7) NOT NULL,
[ExpiresAt] [datetime2](7) NULL,
[StatusName] [nvarchar](50) NOT NULL,
CONSTRAINT [PK_{schema}.Published] PRIMARY KEY CLUSTERED
CONSTRAINT [PK_{schema}.Published] PRIMARY KEY CLUSTERED
(
[Id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
@@ -100,4 +99,4 @@ GO";
return batchSQL;
}
}
}
}

+ 1
- 1
src/DotNetCore.CAP.Kafka/CAP.KafkaCapOptionsExtension.cs Ver ficheiro

@@ -25,4 +25,4 @@ namespace DotNetCore.CAP
services.AddTransient<IQueueExecutor, PublishQueueExecutor>();
}
}
}
}

+ 2
- 2
src/DotNetCore.CAP.Kafka/CAP.KafkaOptions.cs Ver ficheiro

@@ -32,9 +32,9 @@ namespace DotNetCore.CAP

internal IEnumerable<KeyValuePair<string, object>> AsRdkafkaConfig()
{
if (MainConfig.ContainsKey("bootstrap.servers"))
if (MainConfig.ContainsKey("bootstrap.servers"))
return MainConfig.AsEnumerable();
if (string.IsNullOrEmpty(Servers))
{
throw new ArgumentNullException(nameof(Servers));


+ 0
- 1
src/DotNetCore.CAP.Kafka/CAP.Options.Extensions.cs Ver ficheiro

@@ -1,6 +1,5 @@
using System;
using DotNetCore.CAP;
using DotNetCore.CAP.Kafka;

namespace Microsoft.Extensions.DependencyInjection
{


+ 0
- 1
src/DotNetCore.CAP.Kafka/KafkaConsumerClient.cs Ver ficheiro

@@ -81,7 +81,6 @@ namespace DotNetCore.CAP.Kafka
MessageReceieved?.Invoke(sender, message);
}


#endregion private methods
}
}

+ 1
- 1
src/DotNetCore.CAP.Kafka/PublishQueueExecutor.cs Ver ficheiro

@@ -51,4 +51,4 @@ namespace DotNetCore.CAP.Kafka
}
}
}
}
}

+ 1
- 1
src/DotNetCore.CAP.RabbitMQ/CAP.RabbiMQOptions.cs Ver ficheiro

@@ -72,7 +72,7 @@
public int SocketWriteTimeout { get; set; } = DefaultConnectionTimeout;

/// <summary>
/// The port to connect on.
/// The port to connect on.
/// </summary>
public int Port { get; set; } = -1;
}

+ 1
- 1
src/DotNetCore.CAP.RabbitMQ/CAP.RabbitMQCapOptionsExtension.cs Ver ficheiro

@@ -26,4 +26,4 @@ namespace DotNetCore.CAP
services.AddTransient<IQueueExecutor, PublishQueueExecutor>();
}
}
}
}

+ 0
- 1
src/DotNetCore.CAP.RabbitMQ/CapSubscribeAttribute.cs Ver ficheiro

@@ -6,7 +6,6 @@ namespace DotNetCore.CAP.RabbitMQ
{
public CapSubscribeAttribute(string name) : base(name)
{

}
}
}

+ 1
- 2
src/DotNetCore.CAP.RabbitMQ/PublishQueueExecutor.cs Ver ficheiro

@@ -64,7 +64,6 @@ namespace DotNetCore.CAP.RabbitMQ
Description = ex.Message
}));
}

}
}
}
}

+ 1
- 1
src/DotNetCore.CAP/Abstractions/ModelBinding/IModelBinder.cs Ver ficheiro

@@ -14,7 +14,7 @@ namespace DotNetCore.CAP.Abstractions.ModelBinding
/// <returns>
/// <para>
/// A <see cref="Task"/> which will complete when the model binding process completes.
/// </para>
/// </para>
/// </returns>
Task BindModelAsync(ModelBindingContext bindingContext);
}

+ 0
- 1
src/DotNetCore.CAP/CAP.Options.cs Ver ficheiro

@@ -35,7 +35,6 @@ namespace DotNetCore.CAP
/// </summary>
public int PollingDelay { get; set; } = 8;


/// <summary>
/// Registers an extension that will be executed when building services.
/// </summary>


+ 2
- 2
src/DotNetCore.CAP/CAP.ServiceCollectionExtensions.cs Ver ficheiro

@@ -47,12 +47,12 @@ namespace Microsoft.Extensions.DependencyInjection
//Processors
services.AddTransient<PublishQueuer>();
services.AddTransient<SubscribeQueuer>();
services.AddTransient<IDispatcher, DefaultDispatcher>();
services.AddTransient<IDispatcher, DefaultDispatcher>();

//Executors
services.AddSingleton<IQueueExecutorFactory, QueueExecutorFactory>();
services.AddSingleton<IQueueExecutor, SubscibeQueueExecutor>();
//Options
var options = new CapOptions();
setupAction(options);


+ 1
- 1
src/DotNetCore.CAP/ICapOptionsExtension.cs Ver ficheiro

@@ -6,4 +6,4 @@ namespace DotNetCore.CAP
{
void AddServices(IServiceCollection services);
}
}
}

+ 2
- 3
src/DotNetCore.CAP/ICapPublisher.cs Ver ficheiro

@@ -1,5 +1,4 @@
using System;
using System.Data;
using System.Data;
using System.Threading.Tasks;

namespace DotNetCore.CAP
@@ -21,7 +20,7 @@ namespace DotNetCore.CAP
Task PublishAsync(string name, string content);

/// <summary>
/// Publis a object message to specified topic.
/// Publis a object message to specified topic.
/// <para>
/// If you are using the EntityFramework, you need to configure the DbContextType first.
/// otherwise you need to use overloaded method with IDbConnection and IDbTransaction.


+ 0
- 1
src/DotNetCore.CAP/IConsumerHandler.Default.cs Ver ficheiro

@@ -1,5 +1,4 @@
using System;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
using DotNetCore.CAP.Infrastructure;


+ 2
- 5
src/DotNetCore.CAP/IQueueExecutor.cs Ver ficheiro

@@ -1,7 +1,4 @@
using System;
using System.Collections.Generic;
using System.Text;
using System.Threading.Tasks;
using System.Threading.Tasks;

namespace DotNetCore.CAP
{
@@ -9,4 +6,4 @@ namespace DotNetCore.CAP
{
Task<OperateResult> ExecuteAsync(IStorageConnection connection, IFetchedMessage message);
}
}
}

+ 11
- 11
src/DotNetCore.CAP/IStorage.cs Ver ficheiro

@@ -3,14 +3,14 @@ using System.Threading.Tasks;

namespace DotNetCore.CAP
{
/// <summary>
/// Represents a persisted storage.
/// </summary>
public interface IStorage
{
/// <summary>
/// Initializes the storage. For example, making sure a database is created and migrations are applied.
/// </summary>
Task InitializeAsync(CancellationToken cancellationToken);
}
}
/// <summary>
/// Represents a persisted storage.
/// </summary>
public interface IStorage
{
/// <summary>
/// Initializes the storage. For example, making sure a database is created and migrations are applied.
/// </summary>
Task InitializeAsync(CancellationToken cancellationToken);
}
}

+ 9
- 9
src/DotNetCore.CAP/IStorageTransaction.cs Ver ficheiro

@@ -4,16 +4,16 @@ using DotNetCore.CAP.Models;

namespace DotNetCore.CAP
{
public interface IStorageTransaction : IDisposable
{
void UpdateMessage(CapPublishedMessage message);
public interface IStorageTransaction : IDisposable
{
void UpdateMessage(CapPublishedMessage message);

void UpdateMessage(CapReceivedMessage message);
void UpdateMessage(CapReceivedMessage message);

void EnqueueMessage(CapPublishedMessage message);
void EnqueueMessage(CapPublishedMessage message);

void EnqueueMessage(CapReceivedMessage message);
void EnqueueMessage(CapReceivedMessage message);

Task CommitAsync();
}
}
Task CommitAsync();
}
}

+ 1
- 1
src/DotNetCore.CAP/Infrastructure/Helper.cs Ver ficheiro

@@ -40,7 +40,7 @@ namespace DotNetCore.CAP.Infrastructure
public static long ToTimestamp(DateTime value)
{
var elapsedTime = value - Epoch;
return (long) elapsedTime.TotalSeconds;
return (long)elapsedTime.TotalSeconds;
}

public static DateTime FromTimestamp(long value)


+ 2
- 6
src/DotNetCore.CAP/Infrastructure/StatusName.cs Ver ficheiro

@@ -1,8 +1,4 @@
using System;
using System.Collections.Generic;
using System.Text;

namespace DotNetCore.CAP.Infrastructure
namespace DotNetCore.CAP.Infrastructure
{
/// <summary>
/// The message status name.
@@ -15,4 +11,4 @@ namespace DotNetCore.CAP.Infrastructure
public const string Succeeded = nameof(Succeeded);
public const string Failed = nameof(Failed);
}
}
}

+ 1
- 1
src/DotNetCore.CAP/Infrastructure/WaitHandleEx.cs Ver ficheiro

@@ -21,7 +21,7 @@ namespace DotNetCore.CAP.Infrastructure
var tcs = new TaskCompletionSource<bool>();
registeredHandle = ThreadPool.RegisterWaitForSingleObject(
handle,
(state, timedOut) => ((TaskCompletionSource<bool>) state).TrySetResult(!timedOut),
(state, timedOut) => ((TaskCompletionSource<bool>)state).TrySetResult(!timedOut),
tcs,
timeout,
true);


+ 0
- 1
src/DotNetCore.CAP/Internal/IConsumerServiceSelector.Default.cs Ver ficheiro

@@ -44,7 +44,6 @@ namespace DotNetCore.CAP.Internal
return executorDescriptorList;
}


private static IEnumerable<ConsumerExecutorDescriptor> FindConsumersFromInterfaceTypes(
IServiceProvider provider)
{


+ 2
- 2
src/DotNetCore.CAP/Internal/MethodMatcherCache.cs Ver ficheiro

@@ -1,7 +1,7 @@
using System;
using System.Linq;
using System.Collections.Concurrent;
using System.Collections.Generic;
using System.Linq;
using DotNetCore.CAP.Abstractions;

namespace DotNetCore.CAP.Internal
@@ -41,7 +41,7 @@ namespace DotNetCore.CAP.Internal

/// <summary>
/// Get a dictionary of specify topic candidates.
/// The Key is Group name, the value is specify topic candidates.
/// The Key is Group name, the value is specify topic candidates.
/// </summary>
/// <param name="topicName">message topic name</param>
public IDictionary<string, IList<ConsumerExecutorDescriptor>> GetTopicExector(string topicName)


+ 3
- 3
src/DotNetCore.CAP/Internal/ObjectMethodExecutor.cs Ver ficheiro

@@ -130,7 +130,7 @@ namespace DotNetCore.CAP.Internal

private static ConsumerMethodExecutor WrapVoidAction(VoidActionExecutor executor)
{
return delegate(object target, object[] parameters)
return delegate (object target, object[] parameters)
{
executor(target, parameters);
return null;
@@ -192,7 +192,7 @@ namespace DotNetCore.CAP.Internal
/// </summary>
private static async Task<object> CastToObject<T>(Task<T> task)
{
return (object) await task;
return (object)await task;
}

private static Type GetTaskInnerTypeOrNull(Type type)
@@ -279,7 +279,7 @@ namespace DotNetCore.CAP.Internal

private static Task<object> Convert<T>(object taskAsObject)
{
var task = (Task<T>) taskAsObject;
var task = (Task<T>)taskAsObject;
return CastToObject<T>(task);
}



+ 10
- 4
src/DotNetCore.CAP/Internal/SubscriberNotFoundException.cs Ver ficheiro

@@ -1,13 +1,19 @@
using System;

namespace DotNetCore.CAP.Internal
{
public class SubscriberNotFoundException : Exception
{
public SubscriberNotFoundException() { }
public SubscriberNotFoundException()
{
}

public SubscriberNotFoundException(string message) : base(message) { }
public SubscriberNotFoundException(string message) : base(message)
{
}

public SubscriberNotFoundException(string message, Exception inner) :
base(message, inner) { }
base(message, inner)
{ }
}
}
}

+ 0
- 7
src/DotNetCore.CAP/LoggerExtensions.cs Ver ficheiro

@@ -1,7 +1,4 @@
using System;
using System.Collections.Generic;
using System.Linq;
using DotNetCore.CAP.Processor;
using Microsoft.Extensions.Logging;

namespace DotNetCore.CAP
@@ -66,7 +63,6 @@ namespace DotNetCore.CAP
5,
"Received message topic method '{topicName}' failed to execute.");


_jobRetrying = LoggerMessage.Define<int>(
LogLevel.Debug,
3,
@@ -104,19 +100,16 @@ namespace DotNetCore.CAP
_jobFailedWillRetry(logger, ex);
}


public static void JobRetrying(this ILogger logger, int retries)
{
_jobRetrying(logger, retries, null);
}


public static void JobExecuted(this ILogger logger, double seconds)
{
_jobExecuted(logger, seconds, null);
}


public static void ConsumerMethodExecutingFailed(this ILogger logger, string methodName, Exception ex)
{
_executingConsumerMethod(logger, methodName, ex);


+ 2
- 2
src/DotNetCore.CAP/Models/CapPublishedMessage.cs Ver ficheiro

@@ -3,7 +3,7 @@ using DotNetCore.CAP.Infrastructure;

namespace DotNetCore.CAP.Models
{
public class CapPublishedMessage
public class CapPublishedMessage
{
/// <summary>
/// Initializes a new instance of <see cref="CapPublishedMessage"/>.
@@ -22,7 +22,7 @@ namespace DotNetCore.CAP.Models
Content = message.Content;
}

public int Id { get; set; }
public int Id { get; set; }

public string Name { get; set; }



+ 1
- 1
src/DotNetCore.CAP/Models/CapQueue.cs Ver ficheiro

@@ -9,4 +9,4 @@
/// </summary>
public MessageType MessageType { get; set; }
}
}
}

+ 1
- 1
src/DotNetCore.CAP/Models/MessageType.cs Ver ficheiro

@@ -5,4 +5,4 @@
Publish,
Subscribe
}
}
}

+ 2
- 2
src/DotNetCore.CAP/OperateResult.cs Ver ficheiro

@@ -32,7 +32,7 @@ namespace DotNetCore.CAP
/// Returns an <see cref="OperateResult"/> indicating a successful identity operation.
/// </summary>
/// <returns>An <see cref="OperateResult"/> indicating a successful operation.</returns>
public static OperateResult Success { get; } = new OperateResult {Succeeded = true};
public static OperateResult Success { get; } = new OperateResult { Succeeded = true };

/// <summary>
/// Creates an <see cref="OperateResult"/> indicating a failed operation, with a list of <paramref name="errors"/> if applicable.
@@ -41,7 +41,7 @@ namespace DotNetCore.CAP
/// <returns>An <see cref="OperateResult"/> indicating a failed operation, with a list of <paramref name="errors"/> if applicable.</returns>
public static OperateResult Failed(params OperateError[] errors)
{
var result = new OperateResult {Succeeded = false};
var result = new OperateResult { Succeeded = false };
if (errors != null)
{
result._errors.AddRange(errors);


+ 2
- 7
src/DotNetCore.CAP/Processor/IAdditionalProcessor.cs Ver ficheiro

@@ -1,11 +1,6 @@
using System;
using System.Collections.Generic;
using System.Text;

namespace DotNetCore.CAP.Processor
namespace DotNetCore.CAP.Processor
{
public interface IAdditionalProcessor : IProcessor
{

}
}
}

+ 1
- 1
src/DotNetCore.CAP/Processor/IDispatcher.Default.cs Ver ficheiro

@@ -93,4 +93,4 @@ namespace DotNetCore.CAP.Processor
return fetched != null;
}
}
}
}

+ 2
- 6
src/DotNetCore.CAP/Processor/IDispatcher.cs Ver ficheiro

@@ -1,11 +1,7 @@
using System;
using System.Collections.Generic;
using System.Text;

namespace DotNetCore.CAP.Processor
namespace DotNetCore.CAP.Processor
{
public interface IDispatcher : IProcessor
{
bool Waiting { get; }
}
}
}

+ 38
- 38
src/DotNetCore.CAP/Processor/IProcessor.PublishQueuer.cs Ver ficheiro

@@ -2,67 +2,67 @@
using System.Threading;
using System.Threading.Tasks;
using DotNetCore.CAP.Infrastructure;
using DotNetCore.CAP.Processor.States;
using DotNetCore.CAP.Models;
using DotNetCore.CAP.Processor.States;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;

namespace DotNetCore.CAP.Processor
{
public class PublishQueuer : IProcessor
public class PublishQueuer : IProcessor
{
private ILogger _logger;
private CapOptions _options;
private IStateChanger _stateChanger;
private IServiceProvider _provider;
private TimeSpan _pollingDelay;
private ILogger _logger;
private CapOptions _options;
private IStateChanger _stateChanger;
private IServiceProvider _provider;
private TimeSpan _pollingDelay;

public static readonly AutoResetEvent PulseEvent = new AutoResetEvent(true);

public PublishQueuer(
ILogger<PublishQueuer> logger,
IOptions<CapOptions> options,
IStateChanger stateChanger,
IServiceProvider provider)
{
_logger = logger;
_options = options.Value;
_stateChanger = stateChanger;
_provider = provider;
ILogger<PublishQueuer> logger,
IOptions<CapOptions> options,
IStateChanger stateChanger,
IServiceProvider provider)
{
_logger = logger;
_options = options.Value;
_stateChanger = stateChanger;
_provider = provider;

_pollingDelay = TimeSpan.FromSeconds(_options.PollingDelay);
}
_pollingDelay = TimeSpan.FromSeconds(_options.PollingDelay);
}

public async Task ProcessAsync(ProcessingContext context)
{
using (var scope = _provider.CreateScope())
{
public async Task ProcessAsync(ProcessingContext context)
{
using (var scope = _provider.CreateScope())
{
CapPublishedMessage sentMessage;
var provider = scope.ServiceProvider;
var connection = provider.GetRequiredService<IStorageConnection>();
var provider = scope.ServiceProvider;
var connection = provider.GetRequiredService<IStorageConnection>();

while (
!context.IsStopping &&
(sentMessage = await connection.GetNextPublishedMessageToBeEnqueuedAsync()) != null)
while (
!context.IsStopping &&
(sentMessage = await connection.GetNextPublishedMessageToBeEnqueuedAsync()) != null)

{
var state = new EnqueuedState();

using (var transaction = connection.CreateTransaction())
{
_stateChanger.ChangeState(sentMessage, state, transaction);
await transaction.CommitAsync();
}
}
}
using (var transaction = connection.CreateTransaction())
{
_stateChanger.ChangeState(sentMessage, state, transaction);
await transaction.CommitAsync();
}
}
}

context.ThrowIfStopping();
DefaultDispatcher.PulseEvent.Set();

await WaitHandleEx.WaitAnyAsync(PulseEvent,
context.CancellationToken.WaitHandle, _pollingDelay);
}
}
}
}
}
}

+ 2
- 2
src/DotNetCore.CAP/Processor/IProcessor.SubscribeQueuer.cs Ver ficheiro

@@ -2,8 +2,8 @@
using System.Threading;
using System.Threading.Tasks;
using DotNetCore.CAP.Infrastructure;
using DotNetCore.CAP.Processor.States;
using DotNetCore.CAP.Models;
using DotNetCore.CAP.Processor.States;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
@@ -65,4 +65,4 @@ namespace DotNetCore.CAP.Processor
context.CancellationToken.WaitHandle, _pollingDelay);
}
}
}
}

+ 1
- 1
src/DotNetCore.CAP/Processor/RetryBehavior.cs Ver ficheiro

@@ -18,7 +18,7 @@ namespace DotNetCore.CAP.Processor
{
DefaultRetryCount = 25;
DefaultRetryInThunk = retries =>
(int) Math.Round(Math.Pow(retries - 1, 4) + 15 + (_random.Next(30) * (retries)));
(int)Math.Round(Math.Pow(retries - 1, 4) + 15 + (_random.Next(30) * (retries)));

DefaultRetry = new RetryBehavior(true);
NoRetry = new RetryBehavior(false);


+ 3
- 3
src/DotNetCore.CAP/QueueExecutorFactory.cs Ver ficheiro

@@ -18,8 +18,8 @@ namespace DotNetCore.CAP
public IQueueExecutor GetInstance(MessageType messageType)
{
var _queueExectors = _serviceProvider.GetServices<IQueueExecutor>();
if (messageType== MessageType.Publish)
if (messageType == MessageType.Publish)
{
return _queueExectors.FirstOrDefault(x => typeof(BasePublishQueueExecutor).IsAssignableFrom(x.GetType()));
}
@@ -29,4 +29,4 @@ namespace DotNetCore.CAP
}
}
}
}
}

Carregando…
Cancelar
Guardar