This repository has been archived by the owner on Jul 2, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 42
/
Copy pathstorj.h
executable file
·1014 lines (919 loc) · 31.8 KB
/
storj.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
/**
* @file storj.h
* @brief Storj library.
*
* Implements functionality to upload and download files from the Storj
* distributed network.
*/
#ifndef STORJ_H
#define STORJ_H
#ifdef __cplusplus
extern "C" {
#endif
#if defined(_WIN32) && defined(STORJDLL)
#if defined(DLL_EXPORT)
#define STORJ_API __declspec(dllexport)
#else
#define STORJ_API __declspec(dllimport)
#endif
#else
#define STORJ_API
#endif
#include <assert.h>
#include <json-c/json.h>
#include <stdlib.h>
#include <stdio.h>
#include <stdbool.h>
#include <stdarg.h>
#include <string.h>
#include <uv.h>
#include <curl/curl.h>
#include <inttypes.h>
#ifdef _WIN32
#include <time.h>
#endif
#ifndef _WIN32
#include <sys/mman.h>
#include <unistd.h>
#endif
// File transfer success
#define STORJ_TRANSFER_OK 0
#define STORJ_TRANSFER_CANCELED 1
// Bridge related errors 1000 to 1999
#define STORJ_BRIDGE_REQUEST_ERROR 1000
#define STORJ_BRIDGE_AUTH_ERROR 1001
#define STORJ_BRIDGE_TOKEN_ERROR 1002
#define STORJ_BRIDGE_TIMEOUT_ERROR 1003
#define STORJ_BRIDGE_INTERNAL_ERROR 1004
#define STORJ_BRIDGE_RATE_ERROR 1005
#define STORJ_BRIDGE_BUCKET_NOTFOUND_ERROR 1006
#define STORJ_BRIDGE_FILE_NOTFOUND_ERROR 1007
#define STORJ_BRIDGE_JSON_ERROR 1008
#define STORJ_BRIDGE_FRAME_ERROR 1009
#define STORJ_BRIDGE_POINTER_ERROR 1010
#define STORJ_BRIDGE_REPOINTER_ERROR 1011
#define STORJ_BRIDGE_FILEINFO_ERROR 1012
#define STORJ_BRIDGE_BUCKET_FILE_EXISTS 1013
#define STORJ_BRIDGE_OFFER_ERROR 1014
// Farmer related errors 2000 to 2999
#define STORJ_FARMER_REQUEST_ERROR 2000
#define STORJ_FARMER_TIMEOUT_ERROR 2001
#define STORJ_FARMER_AUTH_ERROR 2002
#define STORJ_FARMER_EXHAUSTED_ERROR 2003
#define STORJ_FARMER_INTEGRITY_ERROR 2004
// File related errors 3000 to 3999
#define STORJ_FILE_INTEGRITY_ERROR 3000
#define STORJ_FILE_WRITE_ERROR 3001
#define STORJ_FILE_ENCRYPTION_ERROR 3002
#define STORJ_FILE_SIZE_ERROR 3003
#define STORJ_FILE_DECRYPTION_ERROR 3004
#define STORJ_FILE_GENERATE_HMAC_ERROR 3005
#define STORJ_FILE_READ_ERROR 3006
#define STORJ_FILE_SHARD_MISSING_ERROR 3007
#define STORJ_FILE_RECOVER_ERROR 3008
#define STORJ_FILE_RESIZE_ERROR 3009
#define STORJ_FILE_UNSUPPORTED_ERASURE 3010
#define STORJ_FILE_PARITY_ERROR 3011
// Memory related errors
#define STORJ_MEMORY_ERROR 4000
#define STORJ_MAPPING_ERROR 4001
#define STORJ_UNMAPPING_ERROR 4002
// Queue related errors
#define STORJ_QUEUE_ERROR 5000
// Meta related errors 6000 to 6999
#define STORJ_META_ENCRYPTION_ERROR 6000
#define STORJ_META_DECRYPTION_ERROR 6001
// Miscellaneous errors
#define STORJ_HEX_DECODE_ERROR 7000
// Exchange report codes
#define STORJ_REPORT_SUCCESS 1000
#define STORJ_REPORT_FAILURE 1100
// Exchange report messages
#define STORJ_REPORT_FAILED_INTEGRITY "FAILED_INTEGRITY"
#define STORJ_REPORT_SHARD_DOWNLOADED "SHARD_DOWNLOADED"
#define STORJ_REPORT_SHARD_UPLOADED "SHARD_UPLOADED"
#define STORJ_REPORT_DOWNLOAD_ERROR "DOWNLOAD_ERROR"
#define STORJ_REPORT_UPLOAD_ERROR "TRANSFER_FAILED"
#define STORJ_SHARD_CHALLENGES 4
#define STORJ_LOW_SPEED_LIMIT 30720L
#define STORJ_LOW_SPEED_TIME 20L
#define STORJ_HTTP_TIMEOUT 60L
typedef struct {
uint8_t *encryption_ctr;
uint8_t *encryption_key;
struct aes256_ctx *ctx;
} storj_encryption_ctx_t ;
typedef enum {
STORJ_REPORT_NOT_PREPARED = 0,
STORJ_REPORT_AWAITING_SEND = 1,
STORJ_REPORT_SENDING = 2,
STORJ_REPORT_SENT = 3
} exchange_report_status_t;
/** @brief Bridge configuration options
*
* Proto can be "http" or "https", and the user/pass are used for
* basic authentication to a Storj bridge.
*/
typedef struct {
const char *proto;
const char *host;
int port;
const char *user;
const char *pass;
} storj_bridge_options_t;
/** @brief File encryption options
*
* The mnemonic is a BIP39 secret code used for generating keys for file
* encryption and decryption.
*/
typedef struct storj_encrypt_options {
const char *mnemonic;
} storj_encrypt_options_t;
/** @brief HTTP configuration options
*
* Settings for making HTTP requests
*/
typedef struct storj_http_options {
const char *user_agent;
const char *proxy_url;
const char *cainfo_path;
uint64_t low_speed_limit;
uint64_t low_speed_time;
uint64_t timeout;
} storj_http_options_t;
/** @brief A function signature for logging
*/
typedef void (*storj_logger_fn)(const char *message, int level, void *handle);
/** @brief Logging configuration options
*
* Settings for logging
*/
typedef struct storj_log_options {
storj_logger_fn logger;
int level;
} storj_log_options_t;
/** @brief A function signature for logging
*/
typedef void (*storj_logger_format_fn)(storj_log_options_t *options,
void *handle,
const char *format, ...);
/** @brief Functions for all logging levels
*/
typedef struct storj_log_levels {
storj_logger_format_fn debug;
storj_logger_format_fn info;
storj_logger_format_fn warn;
storj_logger_format_fn error;
} storj_log_levels_t;
/** @brief A structure for a Storj user environment.
*
* This is the highest level structure and holds many commonly used options
* and the event loop for queuing work.
*/
typedef struct storj_env {
storj_bridge_options_t *bridge_options;
storj_encrypt_options_t *encrypt_options;
storj_http_options_t *http_options;
storj_log_options_t *log_options;
const char *tmp_path;
uv_loop_t *loop;
storj_log_levels_t *log;
} storj_env_t;
/** @brief A structure for queueing json request work
*/
typedef struct {
storj_http_options_t *http_options;
storj_bridge_options_t *options;
char *method;
char *path;
bool auth;
struct json_object *body;
struct json_object *response;
int error_code;
int status_code;
void *handle;
} json_request_t;
/** @brief A structure for that describes a bucket
*/
typedef struct {
const char *created;
const char *name;
const char *id;
bool decrypted;
} storj_bucket_meta_t;
/** @brief A structure for queueing create bucket request work
*/
typedef struct {
storj_http_options_t *http_options;
storj_encrypt_options_t *encrypt_options;
storj_bridge_options_t *bridge_options;
const char *bucket_name;
const char *encrypted_bucket_name;
struct json_object *response;
storj_bucket_meta_t *bucket;
int error_code;
int status_code;
void *handle;
} create_bucket_request_t;
/** @brief A structure for queueing list buckets request work
*/
typedef struct {
storj_http_options_t *http_options;
storj_encrypt_options_t *encrypt_options;
storj_bridge_options_t *options;
char *method;
char *path;
bool auth;
struct json_object *body;
struct json_object *response;
storj_bucket_meta_t *buckets;
uint32_t total_buckets;
int error_code;
int status_code;
void *handle;
} get_buckets_request_t;
/** @brief A structure for queueing get bucket request work
*/
typedef struct {
storj_http_options_t *http_options;
storj_encrypt_options_t *encrypt_options;
storj_bridge_options_t *options;
char *method;
char *path;
bool auth;
struct json_object *body;
struct json_object *response;
storj_bucket_meta_t *bucket;
int error_code;
int status_code;
void *handle;
} get_bucket_request_t;
/** @brief A structure for that describes a bucket entry/file
*/
typedef struct {
const char *created;
const char *filename;
const char *mimetype;
const char *erasure;
uint64_t size;
const char *hmac;
const char *id;
bool decrypted;
const char *index;
} storj_file_meta_t;
/** @brief A structure for queueing list files request work
*/
typedef struct {
storj_http_options_t *http_options;
storj_encrypt_options_t *encrypt_options;
storj_bridge_options_t *options;
const char *bucket_id;
char *method;
char *path;
bool auth;
struct json_object *body;
struct json_object *response;
storj_file_meta_t *files;
uint32_t total_files;
int error_code;
int status_code;
void *handle;
} list_files_request_t;
typedef enum {
BUCKET_PUSH,
BUCKET_PULL
} storj_bucket_op_t;
static const char *BUCKET_OP[] = { "PUSH", "PULL" };
/** @brief A data structure that represents an exchange report
*
* These are sent at the end of an exchange with a farmer to report the
* performance and reliability of farmers.
*/
typedef struct {
char *data_hash;
char *reporter_id;
char *farmer_id;
char *client_id;
uint64_t start;
uint64_t end;
unsigned int code;
char *message;
unsigned int send_status;
unsigned int send_count;
uint32_t pointer_index;
} storj_exchange_report_t;
/** @brief A function signature for download/upload progress callback
*/
typedef void (*storj_progress_cb)(double progress,
uint64_t bytes,
uint64_t total_bytes,
void *handle);
/** @brief A function signature for a download complete callback
*/
typedef void (*storj_finished_download_cb)(int status, FILE *fd, void *handle);
/** @brief A function signature for an upload complete callback
*/
typedef void (*storj_finished_upload_cb)(int error_status, char *file_id, void *handle);
/** @brief A structure that represents a pointer to a shard
*
* A shard is an encrypted piece of a file, a pointer holds all necessary
* information to retrieve a shard from a farmer, including the IP address
* and port of the farmer, as well as a token indicating a transfer has been
* authorized. Other necessary information such as the expected hash of the
* data, and the index position in the file is also included.
*
* The data can be replaced with new farmer contact, in case of failure, and the
* total number of replacements can be tracked.
*/
typedef struct {
unsigned int replace_count;
char *token;
char *shard_hash;
uint32_t index;
int status;
uint64_t size;
bool parity;
uint64_t downloaded_size;
char *farmer_id;
char *farmer_address;
int farmer_port;
storj_exchange_report_t *report;
uv_work_t *work;
} storj_pointer_t;
/** @brief A structure for file upload options
*/
typedef struct {
int prepare_frame_limit;
int push_frame_limit;
int push_shard_limit;
bool rs;
const char *index;
const char *bucket_id;
const char *file_name;
FILE *fd;
} storj_upload_opts_t;
/** @brief A structure that keeps state between multiple worker threads,
* and for referencing a download to apply actions to an in-progress download.
*
* After work has been completed in a thread, its after work callback will
* update and modify the state and then queue the next set of work based on the
* changes, and added to the event loop. The state is all managed within one
* thread, the event loop thread, and any work that is performed in another
* thread should not modify this structure directly, but should pass a
* reference to it, so that once the work is complete the state can be updated.
*/
typedef struct {
uint64_t total_bytes;
storj_file_meta_t *info;
bool requesting_info;
uint32_t info_fail_count;
storj_env_t *env;
const char *file_id;
const char *bucket_id;
FILE *destination;
storj_progress_cb progress_cb;
storj_finished_download_cb finished_cb;
bool finished;
bool canceled;
uint64_t shard_size;
uint32_t total_shards;
int download_max_concurrency;
uint32_t completed_shards;
uint32_t resolving_shards;
storj_pointer_t *pointers;
char *excluded_farmer_ids;
uint32_t total_pointers;
uint32_t total_parity_pointers;
bool rs;
bool recovering_shards;
bool truncated;
bool pointers_completed;
uint32_t pointer_fail_count;
bool requesting_pointers;
int error_status;
bool writing;
uint8_t *decrypt_key;
uint8_t *decrypt_ctr;
const char *hmac;
uint32_t pending_work_count;
storj_log_levels_t *log;
void *handle;
} storj_download_state_t;
typedef struct {
char *hash;
uint8_t *challenges[STORJ_SHARD_CHALLENGES][32];
char *challenges_as_str[STORJ_SHARD_CHALLENGES][64 + 1];
// Merkle Tree leaves. Each leaf is size of RIPEMD160 hash
char *tree[2 * STORJ_SHARD_CHALLENGES - 1][20 * 2 + 1];
int index;
bool is_parity;
uint64_t size;
} shard_meta_t;
typedef struct {
char *token;
char *farmer_user_agent;
char *farmer_protocol;
char *farmer_address;
char *farmer_port;
char *farmer_node_id;
} farmer_pointer_t;
typedef struct {
int progress;
int push_frame_request_count;
int push_shard_request_count;
int index;
farmer_pointer_t *pointer;
shard_meta_t *meta;
storj_exchange_report_t *report;
uint64_t uploaded_size;
uv_work_t *work;
} shard_tracker_t;
typedef struct {
storj_env_t *env;
uint32_t shard_concurrency;
const char *index;
const char *file_name;
char *file_id;
const char *encrypted_file_name;
FILE *original_file;
uint64_t file_size;
const char *bucket_id;
char *bucket_key;
uint32_t completed_shards;
uint32_t total_shards;
uint32_t total_data_shards;
uint32_t total_parity_shards;
uint64_t shard_size;
uint64_t total_bytes;
uint64_t uploaded_bytes;
char *exclude;
char *frame_id;
char *hmac_id;
uint8_t *encryption_key;
uint8_t *encryption_ctr;
// TODO: change this to opts or env
bool rs;
bool awaiting_parity_shards;
char *parity_file_path;
FILE *parity_file;
char *encrypted_file_path;
FILE *encrypted_file;
bool creating_encrypted_file;
bool requesting_frame;
bool completed_upload;
bool creating_bucket_entry;
bool received_all_pointers;
bool final_callback_called;
bool canceled;
bool bucket_verified;
bool file_verified;
bool progress_finished;
int push_shard_limit;
int push_frame_limit;
int prepare_frame_limit;
int frame_request_count;
int add_bucket_entry_count;
int bucket_verify_count;
int file_verify_count;
int create_encrypted_file_count;
storj_progress_cb progress_cb;
storj_finished_upload_cb finished_cb;
int error_status;
storj_log_levels_t *log;
void *handle;
shard_tracker_t *shard;
int pending_work_count;
} storj_upload_state_t;
/**
* @brief Initialize a Storj environment
*
* This will setup an event loop for queueing further actions, as well
* as define necessary configuration options for communicating with Storj
* bridge, and for encrypting/decrypting files.
*
* @param[in] options - Storj Bridge API options
* @param[in] encrypt_options - File encryption options
* @param[in] http_options - HTTP settings
* @param[in] log_options - Logging settings
* @return A null value on error, otherwise a storj_env pointer.
*/
STORJ_API storj_env_t *storj_init_env(storj_bridge_options_t *options,
storj_encrypt_options_t *encrypt_options,
storj_http_options_t *http_options,
storj_log_options_t *log_options);
/**
* @brief Destroy a Storj environment
*
* This will free all memory for the Storj environment and zero out any memory
* with sensitive information, such as passwords and encryption keys.
*
* The event loop must be closed before this method should be used.
*
* @param [in] env
*/
STORJ_API int storj_destroy_env(storj_env_t *env);
/**
* @brief Will encrypt and write options to disk
*
* This will encrypt bridge and encryption options to disk using a key
* derivation function on a passphrase.
*
* @param[in] filepath - The file path to save the options
* @param[in] passphrase - Used to encrypt options to disk
* @param[in] bridge_user - The bridge username
* @param[in] bridge_pass - The bridge password
* @param[in] mnemonic - The file encryption mnemonic
* @return A non-zero value on error, zero on success.
*/
STORJ_API int storj_encrypt_write_auth(const char *filepath,
const char *passhrase,
const char *bridge_user,
const char *bridge_pass,
const char *mnemonic);
/**
* @brief Will encrypt options to disk
*
* This will encrypt bridge and encryption using a key
* derivation function on a passphrase.
*
* @param[in] passphrase - Used to encrypt options to disk
* @param[in] bridge_user - The bridge username
* @param[in] bridge_pass - The bridge password
* @param[in] mnemonic - The file encryption mnemonic
* @param[out] buffer - The destination buffer
* @return A non-zero value on error, zero on success.
*/
STORJ_API int storj_encrypt_auth(const char *passhrase,
const char *bridge_user,
const char *bridge_pass,
const char *mnemonic,
char **buffer);
/**
* @brief Will read and decrypt options from disk
*
* This will decrypt bridge and encryption options from disk from
* the passphrase.
*
* @param[in] filepath - The file path to read the options
* @param[in] passphrase - Used to encrypt options to disk
* @param[out] bridge_user - The bridge username
* @param[out] bridge_pass - The bridge password
* @param[out] mnemonic - The file encryption mnemonic
* @return A non-zero value on error, zero on success.
*/
STORJ_API int storj_decrypt_read_auth(const char *filepath,
const char *passphrase,
char **bridge_user,
char **bridge_pass,
char **mnemonic);
/**
* @brief Will decrypt options
*
* This will decrypt bridge and encryption options using key derived
* from a passphrase.
*
* @param[in] buffer - The encrypted buffer
* @param[in] passphrase - Used to encrypt options to disk
* @param[out] bridge_user - The bridge username
* @param[out] bridge_pass - The bridge password
* @param[out] mnemonic - The file encryption mnemonic
* @return A non-zero value on error, zero on success.
*/
STORJ_API int storj_decrypt_auth(const char *buffer,
const char *passphrase,
char **bridge_user,
char **bridge_pass,
char **mnemonic);
/**
* @brief Will get the current unix timestamp in milliseconds
*
* @return A unix timestamp
*/
STORJ_API uint64_t storj_util_timestamp();
/**
* @brief Will generate a new random mnemonic
*
* This will generate a new random mnemonic with 128 to 256 bits
* of entropy.
*
* @param[in] strength - The bits of entropy
* @param[out] buffer - The destination of the mnemonic
* @return A non-zero value on error, zero on success.
*/
STORJ_API int storj_mnemonic_generate(int strength, char **buffer);
/**
* @brief Will check that a mnemonic is valid
*
* This will check that a mnemonic has been entered correctly by verifying
* the checksum, and that words are a part of the list.
*
* @param[in] strength - The bits of entropy
* @return Will return true on success and false failure
*/
STORJ_API bool storj_mnemonic_check(const char *mnemonic);
/**
* @brief Get the error message for an error code
*
* This function will return a error message associated with a storj
* error code.
*
* @param[in] error_code The storj error code integer
* @return A char pointer with error message
*/
STORJ_API char *storj_strerror(int error_code);
/**
* @brief Get Storj bridge API information.
*
* This function will get general information about the storj bridge api.
* The network i/o is performed in a thread pool with a libuv loop, and the
* response is available in the first argument to the callback function.
*
* @param[in] env The storj environment struct
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_get_info(storj_env_t *env,
void *handle,
uv_after_work_cb cb);
/**
* @brief List available buckets for a user.
*
* @param[in] env The storj environment struct
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_get_buckets(storj_env_t *env,
void *handle,
uv_after_work_cb cb);
/**
* @brief Will free all structs for get buckets request
*
* @param[in] req - The work request from storj_bridge_get_buckets callback
*/
STORJ_API void storj_free_get_buckets_request(get_buckets_request_t *req);
/**
* @brief Create a bucket.
*
* @param[in] env The storj environment struct
* @param[in] name The name of the bucket
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_create_bucket(storj_env_t *env,
const char *name,
void *handle,
uv_after_work_cb cb);
/**
* @brief Delete a bucket.
*
* @param[in] env The storj environment struct
* @param[in] id The bucket id
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_delete_bucket(storj_env_t *env,
const char *id,
void *handle,
uv_after_work_cb cb);
/**
* @brief Get a info of specific bucket.
*
* @param[in] env The storj environment struct
* @param[in] bucket_id The bucket id
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_get_bucket(storj_env_t *env,
const char *id,
void *handle,
uv_after_work_cb cb);
/**
* @brief Will free all structs for get bucket request
*
* @param[in] req - The work request from storj_bridge_get_bucket callback
*/
STORJ_API void storj_free_get_bucket_request(get_bucket_request_t *req);
/**
* @brief Get a list of all files in a bucket.
*
* @param[in] env The storj environment struct
* @param[in] id The bucket id
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_list_files(storj_env_t *env,
const char *id,
void *handle,
uv_after_work_cb cb);
/**
* @brief Will free all structs for list files request
*
* @param[in] req - The work request from storj_bridge_list_files callback
*/
STORJ_API void storj_free_list_files_request(list_files_request_t *req);
/**
* @brief Create a PUSH or PULL bucket token.
*
* @param[in] env The storj environment struct
* @param[in] bucket_id The bucket id
* @param[in] operation The type of operation PUSH or PULL
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_create_bucket_token(storj_env_t *env,
const char *bucket_id,
storj_bucket_op_t operation,
void *handle,
uv_after_work_cb cb);
/**
* @brief Get pointers with locations to file shards.
*
* @param[in] env The storj environment struct
* @param[in] bucket_id The bucket id
* @param[in] file_id The bucket id
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_get_file_pointers(storj_env_t *env,
const char *bucket_id,
const char *file_id,
void *handle,
uv_after_work_cb cb);
/**
* @brief Delete a file in a bucket.
*
* @param[in] env The storj environment struct
* @param[in] bucket_id The bucket id
* @param[in] file_id The bucket id
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_delete_file(storj_env_t *env,
const char *bucket_id,
const char *file_id,
void *handle,
uv_after_work_cb cb);
/**
* @brief Create a file frame
*
* @param[in] env The storj environment struct
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_create_frame(storj_env_t *env,
void *handle,
uv_after_work_cb cb);
/**
* @brief List available file frames
*
* @param[in] env The storj environment struct
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_get_frames(storj_env_t *env,
void *handle,
uv_after_work_cb cb);
/**
* @brief Get information for a file frame
*
* @param[in] env The storj environment struct
* @param[in] frame_id The frame id
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_get_frame(storj_env_t *env,
const char *frame_id,
void *handle,
uv_after_work_cb cb);
/**
* @brief Delete a file frame
*
* @param[in] env The storj environment struct
* @param[in] frame_id The frame id
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_delete_frame(storj_env_t *env,
const char *frame_id,
void *handle,
uv_after_work_cb cb);
/**
* @brief Get metadata for a file
*
* @param[in] env The storj environment struct
* @param[in] bucket_id The bucket id
* @param[in] file_id The bucket id
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_get_file_info(storj_env_t *env,
const char *bucket_id,
const char *file_id,
void *handle,
uv_after_work_cb cb);
/**
* @brief Get mirror data for a file
*
* @param[in] env The storj environment struct
* @param[in] bucket_id The bucket id
* @param[in] file_id The bucket id
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_list_mirrors(storj_env_t *env,
const char *bucket_id,
const char *file_id,
void *handle,
uv_after_work_cb cb);
/**
* @brief Will cancel an upload
*
* @param[in] state A pointer to the the upload state
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_store_file_cancel(storj_upload_state_t *state);
/**
* @brief Upload a file
*
* @param[in] env A pointer to environment
* @param[in] state A pointer to the the upload state
* @param[in] opts The options for the upload
* @param[in] handle A pointer that will be available in the callback
* @param[in] progress_cb Function called with progress updates
* @param[in] finished_cb Function called when download finished
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API storj_upload_state_t *storj_bridge_store_file(storj_env_t *env,
storj_upload_opts_t *opts,
void *handle,
storj_progress_cb progress_cb,
storj_finished_upload_cb finished_cb);
/**
* @brief Will cancel a download
*
* @param[in] state A pointer to the the download state
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_resolve_file_cancel(storj_download_state_t *state);
/**
* @brief Download a file
*
* @param[in] env A pointer to environment
* @param[in] state A pointer to the the download state
* @param[in] bucket_id Character array of bucket id
* @param[in] file_id Character array of file id
* @param[in] destination File descriptor of the destination
* @param[in] handle A pointer that will be available in the callback
* @param[in] progress_cb Function called with progress updates
* @param[in] finished_cb Function called when download finished
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API storj_download_state_t *storj_bridge_resolve_file(storj_env_t *env,
const char *bucket_id,
const char *file_id,
FILE *destination,
void *handle,
storj_progress_cb progress_cb,
storj_finished_download_cb finished_cb);
/**
* @brief Register a user
*
* @param[in] env The storj environment struct
* @param[in] email the user's email
* @param[in] password the user's password
* @param[in] handle A pointer that will be available in the callback
* @param[in] cb A function called with response when complete
* @return A non-zero error value on failure and 0 on success.
*/
STORJ_API int storj_bridge_register(storj_env_t *env,
const char *email,
const char *password,
void *handle,
uv_after_work_cb cb);