ncdc/libdc/include/dc/api.h

102 lines
3.4 KiB
C
Raw Normal View History

2019-06-25 14:52:38 +02:00
#ifndef NCDC_API_H
#define NCDC_API_H
#include <dc/apisync.h>
#include <dc/account.h>
2019-06-26 10:48:55 +02:00
#include <dc/guild.h>
2019-07-05 13:37:50 +02:00
#include <dc/channel.h>
2019-06-25 14:52:38 +02:00
#include <stdbool.h>
#include <jansson.h>
#include <event.h>
2019-06-26 10:48:55 +02:00
#include <glib.h>
2019-06-25 14:52:38 +02:00
struct dc_api_;
typedef struct dc_api_ *dc_api_t;
dc_api_t dc_api_new(void);
void dc_api_set_curl_multi(dc_api_t api, CURLM *curl);
void dc_api_set_event_base(dc_api_t api, struct event_base *base);
/* call this function in case the MULTI has told us that some
* transfer has finished.
*/
void dc_api_signal(dc_api_t api, CURL *easy, int code);
/* internal curl stuff
*/
dc_api_sync_t dc_api_call(dc_api_t api, char const *token,
2019-06-25 18:20:27 +02:00
char const *verb, char const *method,
json_t *j);
2019-06-25 14:52:38 +02:00
json_t *dc_api_call_sync(dc_api_t api, char const *token,
2019-06-25 18:20:27 +02:00
char const *verb, char const *method,
json_t *j);
/**
* Authenticate a given user account. The user account should have
* email, and password set. If the auth succeeds the account will have
* a login token, and will from now on be the "login account". You
* will have to pass that account to various other functions for
* authentication.
*/
2019-06-25 14:52:38 +02:00
bool dc_api_authenticate(dc_api_t api, dc_account_t account);
2019-06-25 18:20:27 +02:00
/**
* Retrieve basic user information for the given account. The first
* parameter is the user account holding login info, while the second
2019-07-03 21:14:23 +02:00
* is the account you wish to retrieve information about. If you wish
* to retrieve information about the login user, simply pass the account
* twice.
2019-06-25 18:20:27 +02:00
*/
bool dc_api_get_userinfo(dc_api_t api, dc_account_t login,
dc_account_t user);
2019-06-26 10:48:55 +02:00
/**
* Fetch a list of guilds fro the specified login user. Warning if you
* unref the pointer array, you will also unref all the dc_guild_t objects.
*/
2019-06-25 18:20:27 +02:00
bool dc_api_get_userguilds(dc_api_t api, dc_account_t login,
2019-06-26 10:48:55 +02:00
GPtrArray **guilds);
2019-06-25 14:52:38 +02:00
2019-07-05 13:37:50 +02:00
/**
* Create a 1:1 or 1:N DM channel with the given recipients. The recipients must
* have their ID (snowflake) set. Returns the new channel, complete with ID, and
* all in "channel". Note that the "login" user is automatically added to the DM
* session, so it is not needed to add him to recipients.
*/
bool dc_api_create_channel(dc_api_t api, dc_account_t login,
dc_account_t *recipients, size_t nrecp,
dc_channel_t *channel);
2019-07-02 21:53:29 +02:00
/**
2019-07-03 21:14:23 +02:00
* Fetch a list of friends of the login account "login". The friends are stored
* within the login object.
2019-07-02 21:53:29 +02:00
*/
2019-07-03 21:14:23 +02:00
bool dc_api_get_friends(dc_api_t api, dc_account_t login);
2019-07-02 21:53:29 +02:00
2019-07-03 22:47:12 +02:00
/**
* Add a given account as a friend to the friends list
*/
bool dc_api_add_friend(dc_api_t api, dc_account_t login, dc_account_t friend);
/**
* Remove a given account as a friend to the friends list. Warning: The
* account ID (aka account snowflake) is required to perform this operation,
* so you cannot just do dc_account_from_fullname(). Suggestion: use an object
* from the actual friends list of the account login.
*/
bool dc_api_remove_friend(dc_api_t api, dc_account_t login,
dc_account_t friend);
/**
* Accepts someone who has sent a friend request to you, as a friend. Warning:
* The object "friend" requires an account ID (aka snowflake) for this method
* to work. You should take this object perhaps from the "login"'s friend list.
*/
bool dc_api_accept_friend(dc_api_t api, dc_account_t login,
dc_account_t friend);
2019-06-25 14:52:38 +02:00
#endif