Skip to content

BuiltByBit/ally-csharp-api-wrapper

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

44 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

mcm4csharp

Async MC-Market Ultimate API for C#

Quickstart

Initialise the client somewhere in your program. You should only use one instance throughout it, unless for some reason you're logging in with different tokens:

// ...
ApiClient client = new ApiClient(TokenType.Private, "your_private_token");
// ... or ...
ApiClient client = new ApiClient(TokenType.Shared, "your_shared_token");
// ...

You will need to ensure you're using the right token type. To do so, refer to the API documentation.

To ensure you're correctly authenticated, run:

var response await client.GetHealthAsync();
if (response.Status != "success") {
  // reauthenticate or retry here
}

Invoking the wrapper is straightforward. For methods which have a body, you will need to refer to the appropriate struct. IDs and others are passed by parameters.

Each asynchronous method has a return type of Response<T>:

public struct Response<T> {
	public string Result { get; set; }
	public T Data { get; set; }
	public Error Error { get; set; }
	public ulong RetryAfterMilliseconds { get; set; }
}

Result returns the API-documented result. Data contains reponse data of type T and Error gives any errors listed in the response, where applicable.

Since the API only returns RetryAfterMilliseconds when you're being ratelimited, any time that it is 0 you can assume you're not being ratelimited.

For endpoint that returns a result that can be sorted, sortable options are available under v1.Client.SortableFields; please refer to the xml documentation for information on which field supports which endpoint. You will additionally find defaults there, too.

Ratelimiting

The API wrapper comes with automagic delaying so that you don't accidental spam the API. You can turn this feature off by using:

client.WaitForTimeout = false;

This is not recommended!

Furthermore, if you don't like the messy code that is waiting for a response in the event you are ratelimited (since we delay after you're ratelimited), use the SafeRequestAsync method.

For example

Before

var result = await client.ModifyProfilePostAsync (id, msg);

After

var func = async () => await client.ModifyProfilePostAsync (id, msg);
var result = await client.SafeRequestAsync(func);

Eventful Quickstart

We've begun work on an event-driven listener for the API.

To get started, create your standard API client as usual, then initialise an ApiListener:

ApiListener listener = new(client);

You'll need to add some ISubscriptionProviders to your listener. Each listener contains events for when data is fetched and succeeds, fails and when data has changed. You can, for example, add a HealthProvider:

HealthProvider healthProvider = new ();
healthProvider.DataChanged += async (o, e) => {
	// logic here, e.Content for updated.
};
healthProvider.FetchSuccess += async (o, e) => {
	// logic here, e.Content for data.
};

You can then add it:

listener.AddSubscriptionProvider(healthProvider);

And you're done! You can adjust delays for both your providers and listener. Keep in mind that providers should always make safe requests, so you'll never hit ratelimit issues unless you toggle the dangerous respect ratelimit option in your client (never do this).

Keep in mind that the events are raised on a background thread, not the thread you began with.

Documentation

This project has a Doxyfile availale for you to build documentation.

In the directory /docs, run doxygen using the Doxyfile located in the directory. You will see folders /html and /latex being built respectively.

To access HTML documentation, run /docs/html/index.html. We use doxygen-awesome for the theme.

About

Async MC-Market Ultimate API for C#

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C# 100.0%