init ft (no ack or data yet)
This commit is contained in:
57
ngc_ft1.h
57
ngc_ft1.h
@@ -32,12 +32,15 @@ typedef enum NGC_FT1_file_kind /*: uint8_t*/ {
|
||||
|
||||
// :)
|
||||
// draft for fun and profit
|
||||
// TODO: should we even support v1?
|
||||
// TODO: design the same thing again for tox? (msg_pack instead of bencode?)
|
||||
// id: infohash
|
||||
TORRENT_V1_METAINFO,
|
||||
// id: infohash
|
||||
TORRENT_V2_METAINFO,
|
||||
TORRENT_V1_METAINFO = 8u,
|
||||
// id: sha1
|
||||
TORRENT_V1_CHUNK,
|
||||
|
||||
// id: infohash
|
||||
TORRENT_V2_METAINFO,
|
||||
// id: sha256
|
||||
TORRENT_V2_CHUNK,
|
||||
} NGC_FT1_file_kind;
|
||||
@@ -55,41 +58,45 @@ void NGC_FT1_iterate(Tox *tox, NGC_EXT_CTX* ngc_ext_ctx/*, void *user_data*/);
|
||||
// TODO: remove?
|
||||
void NGC_FT1_request(
|
||||
Tox *tox, NGC_EXT_CTX* ngc_ext_ctx,
|
||||
|
||||
uint32_t group_number,
|
||||
|
||||
NGC_FT1_file_kind file_kind,
|
||||
|
||||
const uint8_t* file_id,
|
||||
size_t file_id_size
|
||||
const uint8_t* file_id, size_t file_id_size
|
||||
);
|
||||
|
||||
void NGC_FT1_request_private(
|
||||
void NGC_FT1_send_request_private(
|
||||
Tox *tox, NGC_EXT_CTX* ngc_ext_ctx,
|
||||
|
||||
uint32_t group_number,
|
||||
uint32_t peer_number,
|
||||
|
||||
uint32_t group_number, uint32_t peer_number,
|
||||
NGC_FT1_file_kind file_kind,
|
||||
|
||||
const uint8_t* file_id,
|
||||
size_t file_id_size
|
||||
const uint8_t* file_id, size_t file_id_size
|
||||
);
|
||||
|
||||
typedef void NGC_FT1_recv_request_cb(Tox *tox, NGC_EXT_CTX* ngc_ext_ctx, uint32_t group_number, uint32_t peer_number, const uint8_t* file_id, size_t file_id_size);
|
||||
|
||||
void NGC_FT1_register_callback_recv_request(NGC_EXT_CTX* ngc_ext_ctx, NGC_FT1_file_kind file_kind, NGC_FT1_recv_request_cb* callback);
|
||||
|
||||
// ========== send/accept ==========
|
||||
|
||||
bool NGC_FT1_send_init_private(
|
||||
Tox *tox, NGC_EXT_CTX* ngc_ext_ctx,
|
||||
uint32_t group_number, uint32_t peer_number,
|
||||
NGC_FT1_file_kind file_kind,
|
||||
const uint8_t* file_id, size_t file_id_size,
|
||||
size_t file_size
|
||||
);
|
||||
|
||||
// return true to accept, false to deny
|
||||
typedef bool NGC_FT1_recv_init_cb(Tox *tox, NGC_EXT_CTX* ngc_ext_ctx, uint32_t group_number, uint32_t peer_number, const uint8_t* file_id, size_t file_id_size, const uint8_t transfer_id, const size_t file_size);
|
||||
|
||||
void NGC_FT1_register_callback_recv_init(NGC_EXT_CTX* ngc_ext_ctx, NGC_FT1_file_kind file_kind, NGC_FT1_recv_init_cb* callback);
|
||||
|
||||
// ========== peer online/offline ==========
|
||||
|
||||
//void NGC_FT1_peer_online(Tox* tox, NGC_FT1* ngc_hs1_ctx, uint32_t group_number, uint32_t peer_number, bool online);
|
||||
|
||||
// "callback"
|
||||
void NGC_FT1_handle_group_custom_packet(
|
||||
Tox* tox,
|
||||
NGC_FT1* ngc_hs1_ctx,
|
||||
|
||||
uint32_t group_number,
|
||||
uint32_t peer_number,
|
||||
|
||||
const uint8_t *data,
|
||||
size_t length
|
||||
Tox* tox, NGC_FT1* ngc_hs1_ctx,
|
||||
uint32_t group_number, uint32_t peer_number,
|
||||
const uint8_t *data, size_t length
|
||||
//void *user_data
|
||||
);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user