Foundatio 12.0.0

Prefix Reserved
dotnet add package Foundatio --version 12.0.0
                    
NuGet\Install-Package Foundatio -Version 12.0.0
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Foundatio" Version="12.0.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Foundatio" Version="12.0.0" />
                    
Directory.Packages.props
<PackageReference Include="Foundatio" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Foundatio --version 12.0.0
                    
#r "nuget: Foundatio, 12.0.0"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Foundatio@12.0.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Foundatio&version=12.0.0
                    
Install as a Cake Addin
#tool nuget:?package=Foundatio&version=12.0.0
                    
Install as a Cake Tool

FoundatioFoundatio

Build status NuGet Version feedz.io Discord

Pluggable foundation blocks for building loosely coupled distributed apps.

Includes implementations in Redis, Azure, AWS, RabbitMQ, Kafka and in memory (for development).

Why Foundatio?

When building several big cloud applications we found a lack of great solutions (that's not to say there isn't solutions out there) for many key pieces to building scalable distributed applications while keeping the development experience simple. Here are a few examples of why we built and use Foundatio:

  • Wanted to build against abstract interfaces so that we could easily change implementations.
  • Wanted the blocks to be dependency injection friendly.
  • Caching: We were initially using an open source Redis cache client but then it turned into a commercial product with high licensing costs. Not only that, but there weren't any in memory implementations so every developer was required to set up and configure Redis.
  • Message Bus: We initially looked at NServiceBus (great product) but it had high licensing costs (they have to eat too) but was not OSS friendly. We also looked into MassTransit (another great product) but found Azure support lacking at the time and local set up a pain (for in memory). We wanted a simple message bus that just worked locally or in the cloud.
  • Storage: We couldn't find any existing project that was decoupled and supported in memory, file storage or Azure Blob Storage.

To summarize, if you want pain free development and testing while allowing your app to scale, use Foundatio!

Implementations

Getting Started (Development)

Foundatio can be installed via the NuGet package manager. If you need help, please open an issue or join our Discord chat room. We’re always here to help if you have any questions!

This section is for development purposes only! If you are trying to use the Foundatio libraries, please get them from NuGet.

  1. You will need to have Visual Studio Code installed.
  2. Open the Foundatio.slnx Visual Studio solution file.

Using Foundatio

The sections below contain a small subset of what's possible with Foundatio. We recommend taking a peek at the source code for more information. Please let us know if you have any questions or need assistance!

Caching

Caching allows you to store and access data lightning fast, saving you exspensive operations to create or get data. We provide four different cache implementations that derive from the ICacheClient interface:

  1. InMemoryCacheClient: An in memory cache client implementation. This cache implementation is only valid for the lifetime of the process. It's worth noting that the in memory cache client has the ability to cache the last X items via the MaxItems property. We use this in Exceptionless to only keep the last 250 resolved geoip results.
  2. HybridCacheClient: This cache implementation uses both an ICacheClient and the InMemoryCacheClient and uses an IMessageBus to keep the cache in sync across processes. This can lead to huge wins in performance as you are saving a serialization operation and a call to the remote cache if the item exists in the local cache.
  3. RedisCacheClient: A Redis cache client implementation.
  4. RedisHybridCacheClient: An implementation of HybridCacheClient that uses the RedisCacheClient as ICacheClient and the RedisMessageBus as IMessageBus.
  5. ScopedCacheClient: This cache implementation takes an instance of ICacheClient and a string scope. The scope is prefixed onto every cache key. This makes it really easy to scope all cache keys and remove them with ease.
Sample
using Foundatio.Caching;

ICacheClient cache = new InMemoryCacheClient();
await cache.SetAsync("test", 1);
var value = await cache.GetAsync<int>("test");

Queues

Queues offer First In, First Out (FIFO) message delivery. We provide four different queue implementations that derive from the IQueue interface:

  1. InMemoryQueue: An in memory queue implementation. This queue implementation is only valid for the lifetime of the process.
  2. RedisQueue: An Redis queue implementation.
  3. AzureServiceBusQueue: An Azure Service Bus Queue implementation.
  4. AzureStorageQueue: An Azure Storage Queue implementation.
  5. SQSQueue: An AWS SQS implementation.
Sample
using Foundatio.Queues;

IQueue<SimpleWorkItem> queue = new InMemoryQueue<SimpleWorkItem>();

await queue.EnqueueAsync(new SimpleWorkItem {
    Data = "Hello"
});

var workItem = await queue.DequeueAsync();

Locks

Locks ensure a resource is only accessed by one consumer at any given time. We provide two different locking implementations that derive from the ILockProvider interface:

  1. CacheLockProvider: A lock implementation that uses cache to communicate between processes.
  2. ThrottlingLockProvider: A lock implementation that only allows a certain amount of locks through. You could use this to throttle api calls to some external service and it will throttle them across all processes asking for that lock.
  3. ScopedLockProvider: This lock implementation takes an instance of ILockProvider and a string scope. The scope is prefixed onto every lock key. This makes it really easy to scope all locks and release them with ease.

It's worth noting that all lock providers take a ICacheClient. This allows you to ensure your code locks properly across machines.

Sample
using Foundatio.Lock;

ILockProvider locker = new CacheLockProvider(new InMemoryCacheClient(), new InMemoryMessageBus());
var testLock = await locker.AcquireAsync("test");
// ...
await testLock.ReleaseAsync();

ILockProvider throttledLocker = new ThrottlingLockProvider(new InMemoryCacheClient(), 1, TimeSpan.FromMinutes(1));
var throttledLock = await throttledLocker.AcquireAsync("test");
// ...
await throttledLock.ReleaseAsync();

Messaging

Allows you to publish and subscribe to messages flowing through your application. We provide four different message bus implementations that derive from the IMessageBus interface:

  1. InMemoryMessageBus: An in memory message bus implementation. This message bus implementation is only valid for the lifetime of the process.
  2. RedisMessageBus: A Redis message bus implementation.
  3. RabbitMQMessageBus: A RabbitMQ implementation.
  4. KafkaMessageBus: A Kafka implementation.
  5. AzureServiceBusMessageBus: An Azure Service Bus implementation.
Sample
using Foundatio.Messaging;

IMessageBus messageBus = new InMemoryMessageBus();
await messageBus.SubscribeAsync<SimpleMessageA>(msg => {
  // Got message
});

await messageBus.PublishAsync(new SimpleMessageA { Data = "Hello" });

Jobs

Allows you to run a long running process (in process or out of process) without worrying about it being terminated prematurely. We provide three different ways of defining a job, based on your use case:

  1. Jobs: All jobs must derive from the IJob interface. We also have a JobBase base class you can derive from which provides a JobContext and logging. You can then run jobs by calling RunAsync() on the job or by creating a instance of the JobRunner class and calling one of the Run methods. The JobRunner can be used to easily run your jobs as Azure Web Jobs.
Sample
using Foundatio.Jobs;

public class HelloWorldJob : JobBase {
  public int RunCount { get; set; }

  protected override Task<JobResult> RunInternalAsync(JobContext context) {
     RunCount++;
     return Task.FromResult(JobResult.Success);
  }
}
var job = new HelloWorldJob();
await job.RunAsync(); // job.RunCount = 1;
await job.RunContinuousAsync(iterationLimit: 2); // job.RunCount = 3;
await job.RunContinuousAsync(cancellationToken: new CancellationTokenSource(10).Token); // job.RunCount > 10;
  1. Queue Processor Jobs: A queue processor job works great for working with jobs that will be driven from queued data. Queue Processor jobs must derive from QueueJobBase<T> class. You can then run jobs by calling RunAsync() on the job or passing it to the JobRunner class. The JobRunner can be used to easily run your jobs as Azure Web Jobs.
Sample
using Foundatio.Jobs;

public class HelloWorldQueueJob : QueueJobBase<HelloWorldQueueItem> {
  public int RunCount { get; set; }

  public HelloWorldQueueJob(IQueue<HelloWorldQueueItem> queue) : base(queue) {}

  protected override Task<JobResult> ProcessQueueEntryAsync(QueueEntryContext<HelloWorldQueueItem> context) {
     RunCount++;

     return Task.FromResult(JobResult.Success);
  }
}

public class HelloWorldQueueItem {
  public string Message { get; set; }
}
 // Register the queue for HelloWorldQueueItem.
container.AddSingleton<IQueue<HelloWorldQueueItem>>(s => new InMemoryQueue<HelloWorldQueueItem>());

// To trigger the job we need to queue the HelloWorldWorkItem message.
// This assumes that we injected an instance of IQueue<HelloWorldWorkItem> queue

IJob job = new HelloWorldQueueJob();
await job.RunAsync(); // job.RunCount = 0; The RunCount wasn't incremented because we didn't enqueue any data.

await queue.EnqueueAsync(new HelloWorldWorkItem { Message = "Hello World" });
await job.RunAsync(); // job.RunCount = 1;

await queue.EnqueueAsync(new HelloWorldWorkItem { Message = "Hello World" });
await queue.EnqueueAsync(new HelloWorldWorkItem { Message = "Hello World" });
await job.RunUntilEmptyAsync(); // job.RunCount = 3;
  1. Work Item Jobs: A work item job will run in a job pool among other work item jobs. This type of job works great for things that don't happen often but should be in a job (Example: Deleting an entity that has many children.). It will be triggered when you publish a message on the message bus. The job must derive from the WorkItemHandlerBase class. You can then run all shared jobs via JobRunner class. The JobRunner can be used to easily run your jobs as Azure Web Jobs.
Sample
using System.Threading.Tasks;
using Foundatio.Jobs;

public class HelloWorldWorkItemHandler : WorkItemHandlerBase {
  public override async Task HandleItemAsync(WorkItemContext ctx) {
    var workItem = ctx.GetData<HelloWorldWorkItem>();

    // We can report the progress over the message bus easily.
    // To receive these messages just inject IMessageSubscriber
    // and Subscribe to messages of type WorkItemStatus
    await ctx.ReportProgressAsync(0, "Starting Hello World Job");
    await Task.Delay(TimeSpan.FromSeconds(2.5));
    await ctx.ReportProgressAsync(50, "Reading value");
    await Task.Delay(TimeSpan.FromSeconds(.5));
    await ctx.ReportProgressAsync(70, "Reading value");
    await Task.Delay(TimeSpan.FromSeconds(.5));
    await ctx.ReportProgressAsync(90, "Reading value.");
    await Task.Delay(TimeSpan.FromSeconds(.5));

    await ctx.ReportProgressAsync(100, workItem.Message);
  }
}

public class HelloWorldWorkItem {
  public string Message { get; set; }
}
// Register the shared job.
var handlers = new WorkItemHandlers();
handlers.Register<HelloWorldWorkItem, HelloWorldWorkItemHandler>();

// Register the handlers with dependency injection.
container.AddSingleton(handlers);

// Register the queue for WorkItemData.
container.AddSingleton<IQueue<WorkItemData>>(s => new InMemoryQueue<WorkItemData>());

// The job runner will automatically look for and run all registered WorkItemHandlers.
new JobRunner(container.GetRequiredService<WorkItemJob>(), instanceCount: 2).RunInBackground();
 // To trigger the job we need to queue the HelloWorldWorkItem message.
 // This assumes that we injected an instance of IQueue<WorkItemData> queue

 // NOTE: You may have noticed that HelloWorldWorkItem doesn't derive from WorkItemData.
 // Foundatio has an extension method that takes the model you post and serializes it to the
 // WorkItemData.Data property.
 await queue.EnqueueAsync(new HelloWorldWorkItem { Message = "Hello World" });

File Storage

We provide different file storage implementations that derive from the IFileStorage interface:

  1. InMemoryFileStorage: An in memory file implementation. This file storage implementation is only valid for the lifetime of the process.
  2. FolderFileStorage: An file storage implementation that uses the hard drive for storage.
  3. AzureFileStorage: An Azure Blob storage implementation.
  4. S3FileStorage: An AWS S3 file storage implementation.
  5. RedisFileStorage: An Redis file storage implementation.
  6. MinioFileStorage An Minio file storage implementation.
  7. AliyunFileStorage: An Aliyun file storage implementation.
  8. SshNetFileStorage: An SFTP file storage implementation.

We recommend using all of the IFileStorage implementations as singletons.

Sample
using Foundatio.Storage;

IFileStorage storage = new InMemoryFileStorage();
await storage.SaveFileAsync("test.txt", "test");
string content = await storage.GetFileContentsAsync("test.txt")

Resilience

Resilience policies provide a powerful way to handle transient failures and make your applications more robust by implementing retry logic, circuit breakers, and timeouts. The resilience system allows you to configure policies globally or per-operation, giving you fine-grained control over how Foundatio components handle failures.

The resilience system is built around the IResiliencePolicy interface and provides:

  1. Retry Logic: Automatically retry failed operations with configurable delays and maximum attempts
  2. Circuit Breaker: Temporarily stop calling failing services to prevent cascading failures
  3. Timeout: Set maximum execution time for operations
  4. Exponential Backoff: Gradually increase delays between retries with optional jitter
  5. Exception Filtering: Configure which exceptions should trigger retries

You can customize resilience behavior throughout Foundatio by implementing IResiliencePolicyProvider and passing it via options. This allows you to replace the default retry behavior in caching, queues, storage, and other Foundatio components.

Resilience Policy Sample
using Foundatio.Resilience;

// Create a basic resilience policy
var policy = new ResiliencePolicyBuilder()
    .WithMaxAttempts(5)
    .WithExponentialDelay(TimeSpan.FromSeconds(1))
    .WithTimeout(TimeSpan.FromMinutes(5))
    .WithJitter()
    .Build();

// Execute an operation with resilience
await policy.ExecuteAsync(async ct => {
    // Your operation that might fail
    await SomeUnreliableOperationAsync(ct);
});
Circuit Breaker Sample
using Foundatio.Resilience;

// Create a policy with circuit breaker
var policy = new ResiliencePolicyBuilder()
    .WithMaxAttempts(3)
    .WithCircuitBreaker(cb => cb
        .WithFailureRatio(0.5) // Open circuit at 50% failure rate
        .WithMinimumCalls(10)  // Need at least 10 calls before opening
        .WithBreakDuration(TimeSpan.FromMinutes(1)))
    .Build();

await policy.ExecuteAsync(async ct => {
    // This will be protected by the circuit breaker
    await CallExternalServiceAsync(ct);
});
Custom Resilience Provider Sample
using Foundatio.Resilience;

// Create a custom resilience provider for your application
var resilienceProvider = new ResiliencePolicyProvider()
    .WithDefaultPolicy(builder => builder
        .WithMaxAttempts(3)
        .WithExponentialDelay(TimeSpan.FromSeconds(1))
        .WithTimeout(TimeSpan.FromMinutes(2)))
    .WithPolicy("external-api", builder => builder
        .WithMaxAttempts(5)
        .WithCircuitBreaker()
        .WithTimeout(TimeSpan.FromSeconds(30)))
    .WithPolicy<MyService>(builder => builder
        .WithMaxAttempts(3)
        .WithLinearDelay()
        .WithTimeout(TimeSpan.FromSeconds(30)));

// Use named policies
var apiPolicy = resilienceProvider.GetPolicy("external-api");
await apiPolicy.ExecuteAsync(async ct => {
    await CallExternalApiAsync(ct);
});

// Use class based policies
var apiPolicy = resilienceProvider.GetPolicy<MyService>();
await apiPolicy.ExecuteAsync(async ct => {
    await CallMyServiceAsync(ct);
});

Sample Application

We have both slides and a sample application that shows off how to use Foundatio.

Thanks to all the people who have contributed

contributors

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (52)

Showing the top 5 NuGet packages that depend on Foundatio:

Package Downloads
Foundatio.Redis

Pluggable foundation blocks for building distributed apps.

Foundatio.JsonNet

Pluggable foundation blocks for building distributed apps.

Foundatio.MetricsNET

Pluggable foundation blocks for building distributed apps.

Foundatio.AzureStorage

Pluggable foundation blocks for building distributed apps.

Foundatio.AzureServiceBus

Pluggable foundation blocks for building distributed apps.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on Foundatio:

Repository Stars
Kaioru/Edelstein
A v.95.1 Mushroom game server emulator written in C# .NET
FoundatioFx/Foundatio.Redis
Foundatio Redis
Version Downloads Last Updated
12.0.0 54,434 8/20/2025
11.1.0 38,663 5/9/2025
11.0.8 88,722 1/31/2025
11.0.7 6,155 1/31/2025
11.0.6 43,664 11/26/2024
11.0.5 26,800 9/27/2024
11.0.4 6,407 9/27/2024
11.0.3 10,762 9/16/2024
11.0.2 35,507 8/31/2024
11.0.1 6,053 8/31/2024
11.0.0 6,468 8/30/2024
10.7.1 3,595,403 3/27/2024
10.7.0 189,834 1/5/2024
10.6.1 384,271 6/23/2023
10.6.0 432,974 1/1/2023
10.5.0 167,818 5/18/2022
10.4.0 45,238 3/7/2022
10.3.1 40,045 1/20/2022
10.3.0 10,241 1/20/2022
10.2.5 166,480 12/7/2021
10.2.4 10,655 12/3/2021
10.2.3 14,428 11/22/2021
10.2.2 213,615 9/23/2021
10.2.1 38,957 7/19/2021
10.2.0 107,763 7/8/2021
10.1.4 26,802 6/16/2021
10.1.3 36,819 4/23/2021
10.1.2 9,117 4/23/2021
10.1.1 12,176 4/15/2021
10.1.0 9,934 4/13/2021
10.0.2 97,373 1/20/2021
10.0.1 45,098 11/2/2020
10.0.0 53,136 9/16/2020
10.0.0-beta9 7,063 8/25/2020
10.0.0-beta8 6,225 8/3/2020
10.0.0-beta7 5,242 7/29/2020
10.0.0-beta6 6,549 7/7/2020
10.0.0-beta5 5,957 6/20/2020
10.0.0-beta3 5,570 6/14/2020
10.0.0-beta2 5,555 6/6/2020
10.0.0-beta10 5,138 9/15/2020
10.0.0-beta1 6,291 5/26/2020
10.0.0-alpha3 3,400 5/5/2020
10.0.0-alpha2 3,410 4/27/2020
10.0.0-alpha1 3,267 4/25/2020
9.1.1 158,382 4/28/2020
9.1.0 10,187 4/28/2020
9.0.0 154,082 1/16/2020
8.1.2126 394,905 8/30/2019
8.1.2058 103,699 5/14/2019
8.1.2027 24,710 4/16/2019
8.0.1965 70,232 2/24/2019
8.0.1948 16,063 2/22/2019
7.1.1845 268,945 11/3/2018
7.1.1841 11,666 11/3/2018
7.1.1837 11,679 11/1/2018
7.1.1833 33,019 11/1/2018
7.0.1831 11,711 11/1/2018
7.0.1818 12,296 10/30/2018
7.0.1738 83,867 9/7/2018
7.0.1706 106,390 5/9/2018
6.0.1586 62,990 11/30/2017
5.1.1562 16,767 10/30/2017
5.1.1521 18,159 9/27/2017
5.1.1515 11,899 9/26/2017
5.1.1501 18,037 9/14/2017
5.1.1498 12,272 8/28/2017
5.1.1492 11,945 8/28/2017
5.1.1490 20,154 8/16/2017
5.1.1474 31,304 8/1/2017
5.1.1470 11,289 7/31/2017
5.1.1457 33,669 6/23/2017
5.1.1448 18,832 5/5/2017
5.1.1443 12,944 5/5/2017
5.0.1336 16,007 3/14/2017
5.0.1334 12,069 3/13/2017
5.0.1331 13,015 3/12/2017
5.0.1329-pre 5,497 3/12/2017
5.0.1328-pre 5,472 3/12/2017
5.0.1327-pre 5,450 3/12/2017
5.0.1326-pre 5,522 3/12/2017
5.0.1324-pre 5,509 3/12/2017
4.3.1323-pre 5,545 3/11/2017
4.3.1319 13,592 3/1/2017
4.3.1317 14,561 2/23/2017
4.3.1316 12,124 2/22/2017
4.3.1315 12,096 2/22/2017
4.3.1314 18,508 2/20/2017
4.3.1312 11,840 2/20/2017
4.3.1311-pre 5,364 2/20/2017
4.3.1307 17,010 2/16/2017
4.3.1306 11,896 2/15/2017
4.3.1305 12,970 2/15/2017
4.3.1304-pre 5,382 2/15/2017
4.3.1303-pre 5,254 2/14/2017
4.3.1301 12,361 2/14/2017
4.3.1299 12,491 2/14/2017
4.3.1297 9,939 2/14/2017
4.3.1293 11,901 2/12/2017
4.3.1292 11,868 2/10/2017
4.3.1291 11,823 2/10/2017
4.3.1290 11,964 2/10/2017
4.3.1289 11,964 2/9/2017
4.3.1288 11,899 2/9/2017
4.3.1286 12,032 2/8/2017
4.3.1282 13,628 2/5/2017
4.3.1281 10,008 2/5/2017
4.3.1280 10,076 2/5/2017
4.3.1276-pre 4,324 2/5/2017
4.3.1177-pre 8,688 9/2/2016
4.3.1164-pre 9,782 8/21/2016
4.2.1205-pre 4,458 9/19/2016
4.2.1183 65,860 9/9/2016
4.2.1179 9,875 9/8/2016
4.2.1176 15,227 9/2/2016
4.2.1172 9,791 9/1/2016
4.2.1171-pre 4,115 9/1/2016
4.2.1169 24,663 8/22/2016
4.2.1167-pre 4,121 8/22/2016
4.2.1166-pre 4,179 8/22/2016
4.2.1161 16,459 8/10/2016
4.2.1156-pre 4,097 8/2/2016
4.2.1155 11,339 8/1/2016
4.2.1150 13,298 7/20/2016
4.2.1149-pre 4,658 7/19/2016
4.2.1148-pre 4,615 7/19/2016
4.2.1147-pre 4,645 7/19/2016
4.2.1146-pre 4,642 7/19/2016
4.2.1137 9,854 7/19/2016
4.2.1129-pre 4,116 7/19/2016
4.2.1128-pre 4,132 7/19/2016
4.2.1127-pre 4,146 7/19/2016
4.2.1126-pre 4,153 7/19/2016
4.2.1125-pre 4,115 7/19/2016
4.2.1123-pre 4,112 7/19/2016
4.2.1119-pre 4,144 7/18/2016
4.2.1113-pre 4,686 7/16/2016
4.2.1108-pre 4,640 7/15/2016
4.2.1107-pre 4,701 7/15/2016
4.2.1104-pre 4,817 7/13/2016
4.2.1099-pre 8,092 7/12/2016
4.2.1098-pre 4,678 7/12/2016
4.2.1093-pre 4,559 7/8/2016
4.2.1091-pre 4,596 7/8/2016
4.2.1090-pre 4,704 7/8/2016
4.2.1089-pre 4,647 7/7/2016
4.2.1087-pre 4,582 7/7/2016
4.2.1083-pre 4,625 7/6/2016
4.2.1082-pre 4,639 7/6/2016
4.2.1081-pre 4,547 7/6/2016
4.2.1079-pre 4,701 7/6/2016
4.2.1078-pre 4,612 7/6/2016
4.2.1073-pre 4,518 7/5/2016
4.2.1070-pre 4,649 7/5/2016
4.2.1069-pre 4,597 7/1/2016
4.2.1059-pre 4,614 7/1/2016
4.2.1046-pre 4,480 6/24/2016
4.2.1031-pre 4,131 6/24/2016
4.2.1028-pre 4,136 6/24/2016
4.2.1027-pre 4,157 6/24/2016
4.1.1009 19,231 6/15/2016
4.1.1002-pre 5,612 6/14/2016
4.1.995-pre 5,830 6/13/2016
4.1.989-pre 5,639 5/26/2016
4.1.983-pre 5,273 5/25/2016
4.1.982-pre 5,256 5/25/2016
4.1.978-pre 5,457 5/6/2016
4.1.977-pre 5,373 5/5/2016
4.1.975-pre 5,867 5/5/2016
4.0.958 14,285 5/1/2016
4.0.957 12,386 4/29/2016
4.0.956 12,400 4/29/2016
4.0.955 12,361 4/28/2016
4.0.941 12,310 4/27/2016
4.0.940 12,384 4/27/2016
4.0.925 12,263 4/27/2016
4.0.922 12,100 4/27/2016
4.0.909 12,298 4/20/2016
4.0.880 12,748 4/7/2016
4.0.869 12,262 3/30/2016
4.0.864 12,081 3/29/2016
4.0.861 12,213 3/29/2016
4.0.860 12,243 3/29/2016
4.0.857 12,121 3/29/2016
4.0.855 12,180 3/29/2016
4.0.846 11,954 3/22/2016
4.0.842 12,076 3/21/2016
4.0.836 11,968 3/18/2016
4.0.835 12,074 3/18/2016
4.0.834 12,058 3/17/2016
4.0.832 11,877 3/17/2016
4.0.831 11,974 3/16/2016
4.0.829 11,901 3/16/2016
4.0.828 11,873 3/15/2016
4.0.827 11,959 3/15/2016
4.0.826 11,695 3/15/2016
4.0.825 12,065 3/13/2016
4.0.821 12,144 3/11/2016
4.0.819 11,926 3/11/2016
4.0.818 11,992 3/11/2016
4.0.816 12,125 3/11/2016
4.0.815 11,769 3/11/2016
4.0.814 12,104 3/11/2016
4.0.813 11,915 3/10/2016
4.0.812 12,158 3/10/2016
4.0.811 11,793 3/10/2016
4.0.810 11,904 3/10/2016
4.0.809 11,943 3/10/2016
4.0.805 11,945 3/9/2016
4.0.797 11,915 3/9/2016
4.0.796 11,886 3/9/2016
4.0.794 11,960 3/9/2016
4.0.793 11,867 3/9/2016
4.0.792 11,858 3/8/2016
4.0.791 17,418 3/8/2016
4.0.790 11,864 3/8/2016
4.0.788 11,917 3/8/2016
4.0.774 12,174 3/2/2016
4.0.773 12,018 3/1/2016
4.0.772 12,065 3/1/2016
4.0.770 11,917 3/1/2016
4.0.769 11,974 3/1/2016
4.0.762 11,945 3/1/2016
4.0.761 12,244 3/1/2016
4.0.760 13,349 2/29/2016
4.0.759 11,949 2/29/2016
4.0.758 12,164 2/29/2016
4.0.757 11,749 2/29/2016
4.0.756 12,281 2/27/2016
4.0.755 12,376 2/27/2016
4.0.754 12,264 2/27/2016
4.0.753 12,249 2/27/2016
4.0.752 12,073 2/27/2016
4.0.750 12,349 2/27/2016
4.0.749 12,288 2/27/2016
4.0.747 12,367 2/26/2016
4.0.746 12,323 2/26/2016
4.0.744 12,239 2/26/2016
4.0.743 12,349 2/26/2016
4.0.742 12,311 2/26/2016
4.0.741 12,178 2/26/2016
4.0.739 11,953 2/25/2016
4.0.738 12,025 2/25/2016
4.0.734 11,775 2/25/2016
4.0.733-beta 5,244 2/25/2016
4.0.672 12,418 2/16/2016
4.0.669 11,880 2/11/2016
4.0.668 42,913 2/11/2016
3.0.654 12,965 2/10/2016
3.0.646 11,570 2/5/2016
3.0.645 11,570 2/5/2016
3.0.644 11,418 2/5/2016
3.0.639 11,441 2/3/2016
3.0.638 11,586 2/2/2016
3.0.637 11,425 2/1/2016
3.0.635 11,449 2/1/2016
3.0.633 15,671 1/27/2016
3.0.632 11,470 1/27/2016
3.0.629 11,631 1/18/2016
3.0.626 11,364 1/18/2016
3.0.625 11,317 1/18/2016
3.0.624 21,797 12/17/2015
3.0.623 11,652 12/9/2015
3.0.622 11,512 12/9/2015
3.0.621 11,591 12/9/2015
3.0.620 11,472 12/8/2015
3.0.613 12,078 12/4/2015
3.0.611 11,619 12/3/2015
3.0.610 11,844 11/30/2015
3.0.606 11,793 11/30/2015
3.0.605 11,784 11/25/2015
3.0.603 11,724 11/23/2015
3.0.601 11,527 11/23/2015
3.0.600 11,503 11/19/2015
3.0.599 11,494 11/19/2015
3.0.598 11,490 11/17/2015
3.0.592 11,417 11/12/2015
3.0.589 11,593 11/10/2015
3.0.588 11,555 11/10/2015
3.0.586 11,560 11/10/2015
3.0.584 11,538 11/10/2015
3.0.583 11,553 11/10/2015
3.0.581 11,825 11/6/2015
3.0.579 11,416 11/6/2015
3.0.576 11,497 11/5/2015
3.0.575 11,460 11/4/2015
3.0.574 11,378 11/4/2015
3.0.569 11,496 11/3/2015
3.0.568 11,520 11/3/2015
3.0.566 11,494 11/3/2015
3.0.548 9,842 11/3/2015
3.0.545 11,702 10/28/2015
3.0.538 11,621 10/22/2015
3.0.537 11,541 10/21/2015
3.0.536 11,564 10/21/2015
3.0.534 11,523 10/21/2015
3.0.532 11,453 10/21/2015
3.0.531 11,554 10/21/2015
3.0.524 11,497 10/15/2015
3.0.523 11,723 10/10/2015
3.0.522 11,467 10/10/2015
3.0.520 11,540 10/9/2015
3.0.519 11,819 10/9/2015
3.0.518 11,671 10/9/2015
3.0.517 11,768 10/9/2015
3.0.516 11,682 10/7/2015
3.0.514 11,770 10/6/2015
3.0.513 11,574 10/6/2015
3.0.512 11,596 10/6/2015
3.0.509 11,738 10/1/2015
3.0.507 11,611 10/1/2015
3.0.505 11,539 9/30/2015
3.0.503 11,630 9/30/2015
3.0.502 11,591 9/30/2015
3.0.479 11,623 9/25/2015
3.0.476 11,530 9/24/2015
3.0.471 11,577 9/24/2015
3.0.470 11,623 9/24/2015
3.0.469 11,548 9/24/2015
3.0.468 11,514 9/24/2015
3.0.467 11,538 9/24/2015
3.0.465 11,551 9/24/2015
3.0.459 11,517 9/23/2015
3.0.456 11,597 9/23/2015
3.0.455 11,565 9/22/2015
3.0.454 11,729 9/19/2015
3.0.453 11,539 9/19/2015
3.0.452 11,449 9/18/2015
3.0.451 11,488 9/18/2015
3.0.450 11,494 9/18/2015
3.0.447 12,888 9/18/2015
2.0.378 11,613 9/5/2015
2.0.372 11,502 9/4/2015
2.0.370 11,559 9/4/2015
2.0.368 11,472 9/4/2015
2.0.365 12,443 9/3/2015
2.0.363 11,436 9/3/2015
2.0.361 11,489 9/3/2015
1.0.360 11,563 9/1/2015
1.0.359 11,469 9/1/2015
1.0.358 11,528 9/1/2015
1.0.356 11,514 8/31/2015
1.0.355 11,549 8/31/2015
1.0.354 11,501 8/29/2015
1.0.305 11,546 8/19/2015
1.0.299 11,978 8/8/2015
1.0.293 11,600 7/20/2015
1.0.292 11,601 7/20/2015
1.0.289 11,696 7/10/2015
1.0.288 11,607 7/10/2015
1.0.286 11,582 7/7/2015
1.0.285 11,655 7/7/2015
1.0.284 11,559 7/7/2015
1.0.282 11,545 7/6/2015
1.0.281 11,555 7/6/2015
1.0.279 11,525 7/6/2015
1.0.277 11,631 6/18/2015
1.0.276 11,607 6/8/2015
1.0.275 11,545 6/8/2015
1.0.274 11,355 6/8/2015
1.0.272 12,232 6/1/2015
1.0.269 11,495 5/25/2015
1.0.268 11,504 5/24/2015
1.0.266 11,434 5/24/2015
1.0.263 11,530 5/21/2015
1.0.258 11,529 5/19/2015
1.0.257 11,555 5/18/2015
1.0.256 11,841 5/17/2015
1.0.254 11,604 5/13/2015
1.0.253 11,494 5/13/2015
1.0.250 11,462 5/13/2015
1.0.249 11,600 5/12/2015
1.0.248 11,501 5/12/2015
1.0.245 11,463 5/12/2015
1.0.241 11,496 5/12/2015
1.0.240 11,289 5/12/2015
1.0.237 11,307 5/11/2015
1.0.234 11,279 5/9/2015
1.0.233 11,148 5/9/2015
1.0.231 11,239 5/7/2015
1.0.230 11,368 5/7/2015
1.0.229 11,240 5/7/2015
1.0.226 11,229 5/7/2015
1.0.217 11,484 4/28/2015
1.0.215 11,380 4/27/2015
1.0.213 11,469 4/23/2015
1.0.210 11,245 4/23/2015
1.0.209 11,239 4/15/2015
1.0.202 11,326 4/15/2015
1.0.201 11,294 4/15/2015
1.0.198 11,210 4/15/2015
1.0.197 11,270 4/15/2015
1.0.196 11,364 4/15/2015
1.0.195 11,320 4/15/2015
1.0.194 11,317 4/15/2015
1.0.193 11,293 4/15/2015
1.0.192 11,239 4/15/2015
1.0.191 11,395 4/14/2015
1.0.189 11,235 4/10/2015
1.0.187 11,322 4/9/2015
1.0.186 11,376 4/8/2015
1.0.185 11,453 4/6/2015
1.0.183 11,153 4/3/2015
1.0.181 11,306 4/3/2015
1.0.180 11,341 4/2/2015
1.0.178 11,267 4/1/2015
1.0.177 11,317 4/1/2015
1.0.175 11,190 4/1/2015
1.0.171 11,201 3/31/2015
1.0.170 11,142 3/31/2015
1.0.168 11,212 3/31/2015
1.0.164 11,521 3/30/2015
1.0.162 11,455 3/28/2015
1.0.160 11,478 3/27/2015
1.0.159 11,488 3/26/2015
1.0.157 11,029 3/24/2015
1.0.156 11,441 3/24/2015
1.0.154 11,390 3/24/2015
1.0.152 11,622 3/24/2015
1.0.151 11,425 3/23/2015
1.0.150 11,479 3/23/2015
1.0.149 11,508 3/23/2015
1.0.148 11,469 3/23/2015
1.0.147 11,374 3/21/2015
1.0.146 11,481 3/20/2015
1.0.145 11,469 3/19/2015
1.0.143 11,610 3/18/2015
1.0.142 11,605 3/12/2015
1.0.141 11,439 3/12/2015
1.0.140 11,411 3/5/2015
1.0.139 11,460 3/5/2015
1.0.138 11,448 3/4/2015
1.0.137 11,380 3/3/2015
1.0.134 11,809 3/3/2015
1.0.129 11,622 3/3/2015
1.0.128 11,529 3/3/2015
1.0.125 11,507 2/28/2015
1.0.124 11,786 2/28/2015
1.0.122 11,538 2/28/2015
1.0.119 11,819 2/25/2015
1.0.117 12,116 2/24/2015
1.0.115 11,868 2/24/2015
1.0.114 11,677 2/23/2015
1.0.113 11,650 2/23/2015
1.0.112 11,769 2/23/2015
1.0.111 11,846 2/23/2015
1.0.110 11,847 2/23/2015
1.0.109 11,751 2/22/2015
1.0.108 11,664 2/22/2015
1.0.103 11,871 2/22/2015
1.0.37 10,510 2/18/2015
1.0.36 10,617 2/18/2015
1.0.35 10,684 2/17/2015
1.0.34 10,637 2/17/2015
1.0.33 10,699 2/17/2015
1.0.32 10,656 2/15/2015
1.0.31 10,651 2/15/2015
1.0.30 10,027 2/15/2015
1.0.28 10,234 2/15/2015
1.0.27 10,091 2/15/2015
1.0.26 10,159 2/13/2015
1.0.25 10,131 2/13/2015
1.0.24 10,060 2/12/2015
1.0.23 10,103 2/12/2015
1.0.0 12,241 2/21/2015