Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/joakimskoog/Cashew
A simple and elegant yet powerful HTTP client cache for .NET
https://github.com/joakimskoog/Cashew
cache caching cashew etag http http-client httpclient
Last synced: 3 months ago
JSON representation
A simple and elegant yet powerful HTTP client cache for .NET
- Host: GitHub
- URL: https://github.com/joakimskoog/Cashew
- Owner: joakimskoog
- License: mit
- Created: 2017-05-20T09:51:55.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2020-02-13T20:18:34.000Z (almost 5 years ago)
- Last Synced: 2024-10-06T10:38:53.409Z (4 months ago)
- Topics: cache, caching, cashew, etag, http, http-client, httpclient
- Language: C#
- Size: 72.3 KB
- Stars: 83
- Watchers: 5
- Forks: 10
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-csharp - Cashew - a .NET library for caching responses easily with an `HttpClient` through an API that is simple and elegant yet powerful. (Caching)
- awesome-dotnet-cn - Cashew - 一个简单、优雅且强大的.NET库,用于通过API使`HttpClient`轻松进行缓存响应。 (缓存)
- awesome-dotnet - Cashew - a .NET library for caching responses easily with an `HttpClient` through an API that is simple and elegant yet powerful. (Caching)
- awesome-dot-dev - Cashew - a .NET library for caching responses easily with an `HttpClient` through an API that is simple and elegant yet powerful. (Caching)
- awsome-dotnet - Cashew - a .NET library for caching responses easily with an `HttpClient` through an API that is simple and elegant yet powerful. (Caching)
- awesome-dotnet - Cashew - a .NET library for caching responses easily with an `HttpClient` through an API that is simple and elegant yet powerful. (Caching)
README
# Cashew
Cashew is a .NET library for caching responses easily with an HttpClient through an API that is simple and elegant yet powerful.
There's support out of the box for the awesome [CacheManager](https://github.com/MichaCo/CacheManager) via the `Cashew.Adapters.CacheManager` package. Its aim is to focus on the HTTP part of caching and not worrying about how stuff is stored, meaning no half-arsed cache implementations!Cashew targets .NET 4.5 and .NET Standard 1.1 (.NET Core, Mono, Xamarin.iOS, Xamarin.Android, UWP and [more](https://github.com/dotnet/standard/blob/master/docs/versions.md)) meaning it can be used on all sorts of devices.
[![Build Status](https://ci.appveyor.com/api/projects/status/github/joakimskoog/Cashew?branch=release&svg=true
)](https://ci.appveyor.com/project/joakimskoog/cashew/history)
[![NuGet](https://img.shields.io/nuget/v/Cashew.svg)](https://www.nuget.org/packages/Cashew/)![Cashew-logo](https://raw.githubusercontent.com/joakimskoog/Cashew/master/Cashew-Logo.png)
# Installation
The latest versions of the packages are available on NuGet. To install, run the following command if you want to roll your own cache:
```
PM> Install-Package Cashew
```
or the command below if you want to utilise the power of [CacheManager](https://github.com/MichaCo/CacheManager)
```
PM> Install-Package Cashew.Adapters.CacheManager
```# Features
## General features
- Extremely easy to use, all it takes is one line to configure the whole thing!
- Simple but powerful API that allows customisation
- [ETag support](https://en.wikipedia.org/wiki/HTTP_ETag)
- [Vary Header support](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Vary)## Cache stores
|Type|Out of the box?|
| ------------- | ------------- |
|Dictionary|Yes*|
|[System.Runtime.Caching.MemoryCache](https://msdn.microsoft.com/en-us/library/system.runtime.caching.memorycache(v=vs.110).aspx)|Yes*|
|[Microsoft.Extensions.Caching.Memory](https://github.com/aspnet/Caching/tree/master/src/Microsoft.Extensions.Caching.Memory)|Yes*|
| [Redis](https://www.nuget.org/packages/CacheManager.StackExchange.Redis) |Yes*|
| [Memcached](https://www.nuget.org/packages/CacheManager.Memcached) |Yes*|
| [Couchbase](https://www.nuget.org/packages/CacheManager.Couchbase) |Yes*|
| Custom | [No, but it's super easy to implement your own](https://github.com/joakimskoog/Cashew/wiki/Custom-cache).|*Provided that you use `Cashew.Adapters.CacheManager`
## HTTP Cache-Control Headers
|Header|Aka|
| ------------- | ------------- |
|[max-age](https://tools.ietf.org/html/rfc7234)|"I don't want cached responses older than this"|
|[s-maxage](https://tools.ietf.org/html/rfc7234)|"I don't want cached responses older than this"|
|[max-stale](https://tools.ietf.org/html/rfc7234)|"Stale responses are OK for this long"|
|[min-fresh](https://tools.ietf.org/html/rfc7234)|"The response has to still be fresh for at least this long"|
|[no-cache](https://tools.ietf.org/html/rfc7234)|"You must validate the cached response with the server|
|[no-store](https://tools.ietf.org/html/rfc7234)|"DO NOT CACHE THIS OR I WILL MAKE YOUR LIFE MISERABLE!"|
|[only-if-cached](https://tools.ietf.org/html/rfc7234)|"I only want a response if it's cached"|
|[must-revalidate](https://tools.ietf.org/html/rfc7234)|"You MUST revalidate stale responses"|
|[proxy-revalidate](https://tools.ietf.org/html/rfc7234)|"You MUST revalidate stale responses"|## Customisation
Cashew provides a lot of customisation opportunities for its users. The most important ones are listed below:|Feature|Quickstart|In-depth|
| ------------- | ------------- | ------------- |
| Use any cache store | [Link](#use-any-cache-store) | [Wiki](https://github.com/joakimskoog/Cashew/wiki/Custom-cache) |
| Decide how cache keys are created | [Link](#decide-how-cache-keys-are-created) | [Wiki](https://github.com/joakimskoog/Cashew/wiki/CacheKeyStrategy) |
| Decide which status codes are cacheable | [Link](#cacheable-status-codes) | [Wiki](https://github.com/joakimskoog/Cashew/wiki/HTTP-Status-Codes) |# Usage
For more in-depth information on how to use Cashew, please refer to our [wiki](https://github.com/joakimskoog/Cashew/wiki).## Configuring HttpClient
```csharp
//All it takes is one line to configure the whole thing!
var httpClient = new HttpClient(new HttpCachingHandler(cache, new HttpStandardKeyStrategy(cache)));
```## Use any cache store
```csharp
//We feel like caching the HTTP responses in an SQL store (for some reason) and have therefore created our own SqlCache
var sqlCache = new SqlCache();//We pass our newly created sql cache in the constructor and watch the magic happen
var httpCachingHandler = new HttpCachingHandler(sqlCache, keyStrategy);
```## Decide how cache keys are created
```csharp
//We have created our own strategy that creates keys out of request URI:s
var uriKeyStrategy = new RequestUriKeyStrategy();//We pass our newly created key strategy in the constructor and watch the magic happen!
var httpCachingHandler = new HttpCachingHandler(memoryCache, uriKeyStrategy);
```## Decide how query strings are handled
```csharp
//The default implementation of ICacheKeyStrategy is HttpStandardKeyStrategy. You can configure it to handle query strings in two ways.//Using CacheKeySetting.Standard will result in a different cache key each time the query string changes
var queryStringStrategy = new HttpStandardKeyStrategy(cache, CacheKeySetting.Standard);//Using CacheKeySetting.IgnoreQueryString will result in the same key even if the query string changes.
var uriStrategy = new HttpStandardKeyStrategy(cache, CacheKeySetting.IgnoreQueryString);
```## Cacheable status codes
```csharp
//We only want to cache responses with status 200
httpCachingHandler.CacheableStatusCodes = new[] { HttpStatusCode.OK };
```# Contributing
Please refer to our [guidelines](https://github.com/joakimskoog/Cashew/wiki/Contributing) on contributing.