Skip to content

HALClient is a standalone client consuming HAL powered hypermedia APIs

Notifications You must be signed in to change notification settings

ecomfi/halclient

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ecomfi/halclient

HALClient is a standalone client consuming HAL powered hypermedia APIs

At the moment there is support written for the JSON variant of HAL. HALClient uses Newtonsoft.JSON to deserialize JSON resources into C# objects with awareness of Hypermedia.

Specification of HAL can be found from http://stateless.co/hal_specification.html

Usage

Embedded resources

class Products : HalResource
{
	[HalEmbedded("products")]
	public List<Product> Items { get; set; }
}

class Product : HalResource
{
	[JsonProperty("name")]
	public string Name { get; set; }

	[HalEmbedded("supplier")]
	public Supplier Supplier { get; set; }

	public int Id { get; set; }
}

class Supplier : HalResource
{
	[JsonProperty("name")]
	public string Name { get; set; }
}


var client = new HalClient("http://exampleapi.com");
client.Get<Products>("/products")
  .ContinueWith(res =>
    {
      var products = res.Result;
      Console.WriteLine("Name of first product is {0}", products.Items.First().Name);
      Console.WriteLine("Supplier of first product is {0}", products.Items.First().Supplier.Name);
    });

Using links

{
  "name": "Test product",
  "_links": {
    "self": {
      "href": "/products/123"
    },
    "supplier": {
      "href": "/suppliers/321"
    }
  }
}
var client = new HalCLient("http://exampleapi.com");
//Product is previously fetched
client.Get<Supplier>(product.Links.GetLink("supplier")).ContinueWith(res => { ...}); //res.Result contains the Supplier

About

HALClient is a standalone client consuming HAL powered hypermedia APIs

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages