Async MC-Market Ultimate API for C#
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.
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
var result = await client.ModifyProfilePostAsync (id, msg);
var func = async () => await client.ModifyProfilePostAsync (id, msg);
var result = await client.SafeRequestAsync(func);
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 ISubscriptionProvider
s 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.
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.