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
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
1599
1600
1601
1602
1603
1604
1605
1606
1607
1608
1609
1610
1611
1612
1613
1614
1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804
1805
1806
1807
1808
1809
1810
1811
1812
1813
1814
1815
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
2134
2135
2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176
2177
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
2192
2193
2194
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204
2205
2206
2207
2208
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233
2234
2235
2236
2237
2238
2239
2240
2241
2242
2243
2244
2245
2246
2247
2248
2249
2250
2251
2252
2253
2254
2255
2256
2257
2258
2259
2260
2261
2262
2263
2264
2265
2266
2267
2268
2269
2270
2271
2272
2273
2274
2275
2276
2277
2278
2279
2280
2281
2282
2283
2284
2285
2286
2287
2288
2289
2290
2291
2292
2293
2294
2295
2296
2297
2298
2299
2300
2301
2302
2303
2304
2305
2306
2307
2308
2309
2310
2311
2312
2313
2314
2315
2316
2317
2318
2319
2320
2321
2322
2323
2324
2325
2326
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336
2337
2338
2339
2340
2341
2342
2343
2344
2345
2346
2347
2348
2349
2350
2351
2352
2353
2354
2355
2356
2357
2358
2359
2360
2361
2362
2363
2364
2365
2366
2367
2368
2369
2370
2371
2372
2373
2374
2375
2376
2377
2378
2379
2380
2381
2382
2383
2384
2385
2386
2387
2388
2389
2390
2391
2392
2393
2394
2395
2396
2397
2398
2399
2400
2401
2402
2403
2404
2405
2406
2407
2408
2409
2410
2411
2412
2413
2414
2415
2416
2417
2418
2419
2420
2421
2422
2423
2424
2425
2426
2427
2428
2429
2430
2431
2432
2433
2434
2435
2436
2437
2438
2439
2440
2441
2442
2443
2444
2445
2446
2447
2448
2449
2450
2451
2452
2453
2454
2455
2456
2457
2458
2459
2460
2461
2462
2463
2464
2465
2466
2467
2468
2469
2470
2471
2472
2473
2474
2475
2476
2477
2478
2479
2480
2481
2482
2483
2484
2485
2486
2487
2488
2489
2490
2491
2492
2493
2494
2495
2496
2497
2498
2499
2500
2501
2502
2503
2504
2505
2506
2507
2508
2509
2510
2511
2512
2513
2514
2515
2516
2517
2518
2519
2520
2521
2522
2523
2524
2525
2526
2527
2528
2529
2530
2531
2532
2533
2534
2535
2536
2537
2538
2539
2540
2541
2542
2543
2544
2545
2546
2547
2548
2549
2550
2551
2552
2553
2554
2555
2556
2557
2558
2559
2560
2561
2562
2563
2564
2565
2566
2567
2568
2569
2570
2571
2572
2573
2574
2575
2576
2577
2578
2579
2580
2581
2582
2583
2584
2585
2586
2587
2588
2589
2590
2591
2592
2593
2594
2595
2596
2597
2598
2599
2600
2601
2602
2603
2604
2605
2606
2607
2608
2609
2610
2611
2612
2613
2614
2615
2616
2617
2618
2619
2620
2621
2622
2623
2624
2625
2626
2627
2628
2629
2630
2631
2632
2633
2634
2635
2636
2637
2638
2639
2640
2641
2642
2643
2644
2645
2646
2647
2648
2649
2650
2651
2652
2653
2654
2655
2656
2657
2658
2659
2660
2661
2662
2663
2664
2665
2666
2667
2668
2669
2670
2671
2672
2673
2674
2675
2676
2677
2678
2679
2680
2681
2682
2683
2684
2685
2686
2687
2688
2689
2690
2691
2692
2693
2694
2695
2696
2697
2698
2699
2700
2701
2702
2703
2704
2705
2706
2707
2708
2709
2710
2711
2712
2713
2714
2715
2716
2717
2718
2719
2720
2721
2722
2723
2724
2725
2726
2727
2728
2729
2730
2731
2732
2733
2734
2735
2736
2737
2738
2739
2740
2741
2742
2743
2744
2745
2746
2747
2748
2749
2750
2751
2752
2753
2754
2755
2756
2757
2758
2759
2760
2761
2762
2763
2764
2765
2766
2767
2768
2769
2770
2771
2772
2773
2774
2775
2776
2777
2778
2779
2780
2781
2782
2783
2784
2785
2786
2787
2788
2789
2790
2791
2792
2793
2794
2795
2796
2797
2798
2799
2800
2801
2802
2803
2804
2805
2806
2807
2808
2809
2810
2811
2812
2813
2814
2815
2816
2817
2818
2819
2820
2821
2822
2823
2824
2825
2826
2827
2828
2829
2830
2831
2832
2833
2834
2835
2836
2837
2838
2839
2840
2841
2842
2843
2844
2845
2846
2847
2848
2849
2850
2851
2852
2853
2854
2855
2856
2857
2858
2859
2860
2861
2862
2863
2864
2865
2866
2867
2868
2869
2870
2871
2872
2873
2874
2875
2876
2877
2878
2879
2880
2881
2882
2883
2884
2885
2886
2887
2888
2889
2890
2891
2892
2893
2894
2895
2896
2897
2898
2899
2900
2901
2902
2903
2904
2905
2906
2907
2908
2909
2910
2911
2912
2913
2914
2915
2916
2917
2918
2919
2920
2921
2922
2923
2924
2925
2926
2927
2928
2929
2930
2931
2932
2933
2934
2935
2936
2937
2938
2939
2940
2941
2942
2943
2944
2945
2946
2947
2948
2949
2950
2951
2952
2953
2954
2955
2956
2957
2958
2959
2960
2961
2962
2963
2964
2965
2966
2967
2968
2969
2970
2971
2972
2973
2974
2975
2976
2977
2978
2979
2980
2981
2982
2983
2984
2985
2986
2987
2988
2989
2990
2991
2992
2993
2994
2995
2996
2997
2998
2999
3000
3001
3002
3003
3004
3005
3006
3007
3008
3009
3010
3011
3012
3013
3014
3015
3016
3017
3018
3019
3020
3021
3022
3023
3024
3025
3026
3027
3028
3029
3030
3031
3032
3033
3034
3035
3036
3037
3038
3039
3040
3041
3042
3043
3044
3045
3046
3047
3048
3049
3050
3051
3052
3053
3054
3055
3056
3057
3058
3059
3060
3061
3062
3063
3064
3065
3066
3067
3068
3069
3070
3071
3072
3073
3074
3075
3076
3077
3078
3079
3080
3081
3082
3083
3084
3085
3086
3087
3088
3089
3090
3091
3092
3093
3094
3095
3096
3097
3098
3099
3100
3101
3102
3103
3104
3105
3106
3107
3108
3109
3110
3111
3112
3113
3114
3115
3116
3117
3118
3119
3120
3121
3122
3123
3124
3125
3126
3127
3128
3129
3130
3131
3132
3133
3134
3135
3136
3137
3138
3139
3140
3141
3142
3143
3144
3145
3146
3147
3148
3149
3150
3151
3152
3153
3154
3155
3156
3157
3158
3159
3160
3161
3162
3163
3164
3165
3166
3167
3168
3169
3170
3171
3172
3173
3174
3175
3176
3177
3178
3179
3180
3181
3182
3183
3184
3185
3186
3187
3188
3189
3190
3191
3192
3193
3194
3195
3196
3197
3198
3199
3200
3201
3202
3203
3204
3205
3206
3207
3208
3209
3210
3211
3212
3213
3214
3215
3216
3217
3218
3219
3220
3221
3222
3223
3224
3225
3226
3227
3228
3229
3230
3231
3232
3233
3234
3235
3236
3237
3238
3239
3240
3241
3242
3243
3244
3245
3246
3247
3248
3249
3250
3251
3252
3253
3254
3255
3256
3257
3258
3259
3260
3261
3262
3263
3264
3265
3266
3267
3268
3269
3270
3271
3272
3273
3274
3275
3276
3277
3278
3279
3280
3281
3282
3283
3284
3285
3286
3287
3288
3289
3290
3291
3292
3293
3294
3295
3296
3297
3298
3299
3300
3301
3302
3303
3304
3305
3306
3307
3308
3309
3310
3311
3312
3313
3314
3315
3316
3317
3318
3319
3320
3321
3322
3323
3324
3325
3326
3327
3328
3329
3330
3331
3332
3333
3334
3335
3336
3337
3338
3339
3340
3341
3342
3343
3344
3345
3346
3347
3348
3349
3350
3351
3352
3353
3354
3355
3356
3357
3358
3359
3360
3361
3362
3363
3364
3365
3366
3367
3368
3369
3370
3371
3372
3373
3374
3375
3376
3377
3378
3379
3380
3381
3382
3383
3384
3385
3386
3387
3388
3389
3390
3391
3392
3393
3394
3395
3396
3397
3398
3399
3400
3401
3402
3403
3404
3405
3406
3407
3408
3409
3410
3411
3412
3413
3414
3415
3416
3417
3418
3419
3420
3421
3422
3423
3424
3425
3426
3427
3428
3429
3430
3431
3432
3433
3434
3435
3436
3437
3438
3439
3440
3441
3442
3443
3444
3445
3446
3447
3448
3449
3450
3451
3452
3453
3454
3455
3456
3457
3458
3459
3460
3461
3462
3463
3464
3465
3466
3467
3468
3469
3470
3471
3472
3473
3474
3475
3476
3477
3478
3479
3480
3481
3482
3483
3484
3485
3486
3487
3488
3489
3490
3491
3492
3493
3494
3495
3496
3497
3498
3499
3500
3501
3502
3503
3504
3505
3506
3507
3508
3509
3510
3511
3512
3513
3514
3515
3516
3517
3518
3519
3520
3521
3522
3523
3524
3525
3526
3527
3528
3529
3530
3531
3532
3533
3534
3535
3536
3537
3538
3539
3540
3541
3542
3543
3544
3545
3546
3547
3548
3549
3550
3551
3552
3553
3554
3555
3556
3557
3558
3559
3560
3561
3562
3563
3564
3565
3566
3567
3568
3569
3570
3571
3572
3573
3574
3575
3576
3577
3578
3579
3580
3581
3582
3583
3584
3585
3586
3587
3588
3589
3590
3591
3592
3593
3594
3595
3596
3597
3598
3599
3600
3601
3602
3603
3604
3605
3606
3607
3608
3609
3610
3611
3612
3613
3614
3615
3616
3617
3618
3619
3620
3621
3622
3623
3624
3625
3626
3627
3628
3629
3630
3631
3632
3633
3634
3635
3636
3637
3638
3639
3640
3641
3642
3643
3644
3645
3646
3647
3648
3649
3650
3651
3652
3653
3654
3655
3656
3657
3658
3659
3660
3661
3662
3663
3664
3665
3666
3667
3668
3669
3670
3671
3672
3673
3674
3675
3676
3677
3678
3679
3680
3681
3682
3683
3684
3685
3686
3687
3688
3689
3690
3691
3692
3693
3694
3695
3696
3697
3698
3699
3700
3701
3702
3703
3704
3705
3706
3707
3708
3709
3710
3711
3712
3713
3714
3715
3716
3717
3718
3719
3720
3721
3722
3723
3724
3725
3726
3727
3728
3729
3730
3731
3732
3733
3734
3735
3736
3737
3738
3739
3740
3741
3742
3743
3744
3745
3746
3747
3748
3749
3750
3751
3752
3753
3754
3755
3756
3757
3758
3759
3760
3761
3762
3763
3764
3765
3766
3767
3768
3769
3770
3771
3772
3773
3774
3775
3776
3777
3778
3779
3780
3781
3782
3783
3784
3785
3786
3787
3788
3789
3790
3791
3792
3793
3794
3795
3796
3797
3798
3799
3800
3801
3802
3803
3804
3805
3806
3807
3808
3809
3810
3811
3812
3813
3814
3815
3816
3817
3818
3819
3820
3821
3822
3823
3824
3825
3826
3827
3828
3829
3830
3831
3832
3833
3834
3835
3836
3837
3838
3839
3840
3841
3842
3843
3844
3845
3846
3847
3848
3849
3850
3851
3852
3853
3854
3855
3856
3857
3858
3859
3860
3861
3862
3863
3864
3865
3866
3867
3868
3869
3870
3871
3872
3873
3874
3875
3876
3877
3878
3879
3880
3881
3882
3883
3884
3885
3886
3887
3888
3889
3890
3891
3892
3893
3894
3895
3896
3897
3898
3899
3900
3901
3902
3903
3904
3905
3906
3907
3908
3909
3910
3911
3912
3913
3914
3915
3916
3917
3918
3919
3920
3921
3922
3923
3924
3925
3926
3927
3928
3929
3930
3931
3932
3933
3934
3935
3936
3937
3938
3939
3940
3941
3942
3943
3944
3945
3946
3947
3948
3949
3950
3951
3952
3953
3954
3955
3956
3957
3958
3959
3960
3961
3962
3963
3964
3965
3966
3967
3968
3969
3970
3971
3972
3973
3974
3975
3976
3977
3978
3979
3980
3981
3982
3983
3984
3985
3986
3987
3988
3989
3990
3991
3992
3993
3994
3995
3996
3997
3998
3999
4000
4001
4002
4003
4004
4005
4006
4007
4008
4009
4010
4011
4012
4013
4014
4015
4016
4017
4018
4019
4020
4021
4022
4023
4024
4025
4026
4027
4028
4029
4030
4031
4032
4033
4034
4035
4036
4037
4038
4039
4040
4041
4042
4043
4044
4045
4046
4047
4048
4049
4050
4051
4052
4053
4054
4055
4056
4057
4058
4059
4060
4061
4062
4063
4064
4065
4066
4067
4068
4069
4070
4071
4072
4073
4074
4075
4076
4077
4078
4079
4080
4081
4082
4083
4084
4085
4086
4087
4088
4089
4090
4091
4092
4093
4094
4095
4096
4097
4098
4099
4100
4101
4102
4103
4104
4105
4106
4107
4108
4109
4110
4111
4112
4113
4114
4115
4116
4117
4118
4119
4120
4121
4122
4123
4124
4125
4126
4127
4128
4129
4130
4131
4132
4133
4134
4135
4136
4137
4138
4139
4140
4141
4142
4143
4144
4145
4146
4147
4148
4149
4150
4151
4152
4153
4154
4155
4156
4157
4158
4159
4160
4161
4162
4163
4164
4165
4166
4167
4168
4169
4170
4171
4172
4173
4174
4175
4176
4177
4178
4179
4180
4181
4182
4183
4184
4185
4186
4187
4188
4189
4190
4191
4192
4193
4194
4195
4196
4197
4198
4199
4200
4201
4202
4203
4204
4205
4206
4207
4208
4209
4210
4211
4212
4213
4214
4215
4216
4217
4218
4219
4220
4221
4222
4223
4224
4225
4226
4227
4228
4229
4230
4231
4232
4233
4234
4235
4236
4237
4238
4239
4240
4241
4242
4243
4244
4245
4246
4247
4248
4249
4250
4251
4252
4253
4254
4255
4256
4257
4258
4259
4260
4261
4262
4263
4264
4265
4266
4267
4268
4269
4270
4271
4272
4273
4274
4275
4276
4277
4278
4279
4280
4281
4282
4283
4284
4285
4286
4287
4288
4289
4290
4291
4292
4293
4294
4295
4296
4297
4298
4299
4300
4301
4302
4303
4304
4305
4306
4307
4308
4309
4310
4311
4312
4313
4314
4315
4316
4317
4318
4319
4320
4321
4322
4323
4324
4325
4326
4327
4328
4329
4330
4331
4332
4333
4334
4335
4336
4337
4338
4339
4340
4341
4342
4343
4344
4345
4346
4347
4348
4349
4350
4351
4352
4353
4354
4355
4356
4357
4358
4359
4360
4361
4362
4363
4364
4365
4366
4367
4368
4369
4370
4371
4372
4373
4374
4375
4376
4377
4378
4379
4380
4381
4382
4383
4384
4385
4386
4387
4388
4389
4390
4391
4392
4393
4394
4395
4396
4397
4398
4399
4400
4401
4402
4403
4404
4405
4406
4407
4408
4409
4410
4411
4412
4413
4414
4415
4416
4417
4418
4419
4420
4421
4422
4423
4424
4425
4426
4427
4428
4429
4430
4431
4432
4433
4434
4435
4436
4437
4438
4439
4440
4441
4442
4443
4444
4445
4446
4447
4448
4449
4450
4451
4452
4453
4454
4455
4456
4457
4458
4459
4460
4461
4462
4463
4464
4465
4466
4467
4468
4469
4470
4471
4472
4473
4474
4475
4476
4477
4478
4479
4480
4481
4482
4483
4484
4485
4486
4487
4488
4489
4490
4491
4492
4493
4494
4495
4496
4497
4498
4499
4500
4501
4502
4503
4504
4505
4506
4507
4508
4509
4510
4511
4512
4513
4514
4515
4516
4517
4518
4519
4520
4521
4522
4523
4524
4525
4526
4527
4528
4529
4530
4531
4532
4533
4534
4535
4536
4537
4538
4539
4540
4541
4542
4543
4544
4545
4546
4547
4548
4549
4550
4551
4552
4553
4554
4555
4556
4557
4558
4559
4560
4561
4562
4563
4564
4565
4566
4567
4568
4569
4570
4571
4572
4573
4574
4575
4576
4577
4578
4579
4580
4581
4582
4583
4584
4585
4586
4587
4588
4589
4590
4591
4592
4593
4594
4595
4596
4597
4598
4599
4600
4601
4602
4603
4604
4605
4606
4607
4608
4609
4610
4611
4612
4613
4614
4615
4616
4617
4618
4619
4620
4621
4622
4623
4624
4625
4626
4627
4628
4629
4630
4631
4632
4633
4634
4635
4636
4637
4638
4639
4640
4641
4642
4643
4644
4645
4646
4647
4648
4649
4650
4651
4652
4653
4654
4655
4656
4657
4658
4659
4660
4661
4662
4663
4664
4665
4666
4667
4668
4669
4670
4671
4672
4673
4674
4675
4676
4677
4678
4679
4680
4681
4682
4683
4684
4685
4686
4687
4688
4689
4690
4691
4692
4693
4694
4695
4696
4697
4698
4699
4700
4701
4702
4703
4704
4705
4706
4707
4708
4709
4710
4711
4712
4713
4714
4715
4716
4717
4718
4719
4720
4721
4722
4723
4724
4725
4726
4727
4728
4729
4730
4731
4732
4733
4734
4735
4736
4737
4738
4739
4740
4741
4742
4743
4744
4745
4746
4747
4748
4749
4750
4751
4752
4753
4754
4755
4756
4757
4758
4759
4760
4761
4762
4763
4764
4765
4766
4767
4768
4769
4770
4771
4772
4773
4774
4775
4776
4777
4778
4779
4780
4781
4782
4783
4784
4785
4786
4787
4788
4789
4790
4791
4792
4793
4794
4795
4796
4797
4798
4799
4800
4801
4802
4803
4804
4805
4806
4807
4808
4809
4810
4811
4812
4813
4814
4815
4816
4817
4818
4819
4820
4821
4822
4823
4824
4825
4826
4827
4828
4829
4830
4831
4832
4833
4834
4835
4836
4837
4838
4839
4840
4841
4842
4843
4844
4845
4846
4847
4848
4849
4850
4851
4852
4853
4854
4855
4856
4857
4858
4859
4860
4861
4862
4863
4864
4865
4866
4867
4868
4869
4870
4871
4872
4873
4874
4875
4876
4877
4878
4879
4880
4881
4882
4883
4884
4885
4886
4887
4888
4889
4890
4891
4892
4893
4894
4895
4896
4897
4898
4899
4900
4901
4902
4903
4904
4905
4906
4907
4908
4909
4910
4911
4912
4913
4914
4915
4916
4917
4918
4919
4920
4921
4922
4923
4924
4925
4926
4927
4928
4929
4930
4931
4932
4933
4934
4935
4936
4937
4938
4939
4940
4941
4942
4943
4944
4945
4946
4947
4948
4949
4950
4951
4952
4953
4954
4955
4956
4957
4958
4959
4960
4961
4962
4963
4964
4965
4966
4967
4968
4969
4970
4971
4972
4973
4974
4975
4976
4977
4978
4979
4980
4981
4982
4983
4984
4985
4986
4987
4988
4989
4990
4991
4992
4993
4994
4995
4996
4997
4998
4999
5000
5001
5002
5003
5004
5005
5006
5007
5008
5009
5010
5011
5012
5013
5014
5015
5016
5017
5018
5019
5020
5021
5022
5023
5024
5025
5026
5027
5028
5029
5030
5031
5032
5033
5034
5035
5036
5037
5038
5039
5040
5041
5042
5043
5044
5045
5046
5047
5048
5049
5050
5051
5052
5053
5054
5055
5056
5057
5058
5059
5060
5061
5062
5063
5064
5065
5066
5067
5068
5069
5070
5071
5072
5073
5074
5075
5076
5077
5078
5079
5080
5081
5082
5083
5084
5085
5086
5087
5088
5089
5090
5091
5092
5093
5094
5095
5096
5097
5098
5099
5100
5101
5102
5103
5104
5105
5106
5107
5108
5109
5110
5111
5112
5113
5114
5115
5116
5117
5118
5119
5120
5121
5122
5123
5124
5125
5126
5127
5128
5129
5130
5131
5132
5133
5134
5135
5136
5137
5138
5139
5140
5141
5142
5143
5144
5145
5146
5147
5148
5149
5150
5151
5152
5153
5154
5155
5156
5157
5158
5159
5160
5161
5162
5163
5164
5165
5166
5167
5168
5169
5170
5171
5172
5173
5174
5175
5176
5177
5178
5179
5180
5181
5182
5183
5184
5185
5186
5187
5188
5189
5190
5191
5192
5193
5194
5195
5196
5197
5198
5199
5200
5201
5202
5203
5204
5205
5206
5207
5208
5209
5210
5211
5212
5213
5214
5215
5216
5217
5218
5219
5220
5221
5222
5223
5224
5225
5226
5227
5228
5229
5230
5231
5232
5233
5234
5235
5236
5237
5238
5239
5240
5241
5242
5243
5244
5245
5246
5247
5248
5249
5250
5251
5252
5253
5254
5255
5256
5257
5258
5259
5260
5261
5262
5263
5264
5265
5266
5267
5268
5269
5270
5271
5272
5273
5274
5275
5276
5277
5278
5279
5280
5281
5282
5283
5284
5285
5286
5287
5288
5289
5290
5291
5292
5293
5294
5295
5296
5297
5298
5299
5300
5301
5302
5303
5304
5305
5306
5307
5308
5309
5310
5311
5312
5313
5314
5315
5316
5317
5318
5319
5320
5321
5322
5323
5324
5325
5326
5327
5328
5329
5330
5331
5332
5333
5334
5335
5336
5337
5338
5339
5340
5341
5342
5343
5344
5345
5346
5347
5348
5349
5350
5351
5352
5353
5354
5355
5356
5357
5358
5359
5360
5361
5362
5363
5364
5365
5366
5367
5368
5369
5370
5371
5372
5373
5374
5375
5376
5377
5378
5379
5380
5381
5382
5383
5384
5385
5386
5387
5388
5389
5390
5391
5392
5393
5394
5395
5396
5397
5398
5399
5400
5401
5402
5403
5404
5405
5406
5407
5408
5409
5410
5411
5412
5413
5414
5415
5416
5417
5418
5419
5420
5421
5422
5423
5424
5425
5426
5427
5428
5429
5430
5431
5432
5433
5434
5435
5436
5437
5438
5439
5440
5441
5442
5443
5444
5445
5446
5447
5448
5449
5450
5451
5452
5453
5454
5455
5456
5457
5458
5459
5460
5461
5462
5463
5464
5465
5466
5467
5468
5469
5470
5471
5472
5473
5474
5475
5476
5477
5478
5479
5480
5481
5482
5483
5484
5485
5486
5487
5488
5489
5490
5491
5492
5493
5494
5495
5496
5497
5498
5499
5500
5501
5502
5503
5504
5505
5506
5507
5508
|
/* SPDX-License-Identifier: GPL-3.0-or-later
* Copyright © 2016-2018 The TokTok team.
* Copyright © 2013 Tox project.
*/
/** @file
* @brief Public core API for Tox clients.
*
* Every function that can fail takes a function-specific error code pointer
* that can be used to diagnose problems with the Tox state or the function
* arguments. The error code pointer can be NULL, which does not influence the
* function's behaviour, but can be done if the reason for failure is irrelevant
* to the client.
*
* The exception to this rule are simple allocation functions whose only failure
* mode is allocation failure. They return NULL in that case, and do not set an
* error code.
*
* Every error code type has an OK value to which functions will set their error
* code value on success. Clients can keep their error code uninitialised before
* passing it to a function. The library guarantees that after returning, the
* value pointed to by the error code pointer has been initialised.
*
* Functions with pointer parameters often have a NULL error code, meaning they
* could not perform any operation, because one of the required parameters was
* NULL. Some functions operate correctly or are defined as effectless on NULL.
*
* Some functions additionally return a value outside their
* return type domain, or a bool containing true on success and false on
* failure.
*
* All functions that take a Tox instance pointer will cause undefined behaviour
* when passed a NULL Tox pointer.
*
* All integer values are expected in host byte order.
*
* Functions with parameters with enum types cause unspecified behaviour if the
* enumeration value is outside the valid range of the type. If possible, the
* function will try to use a sane default, but there will be no error code,
* and one possible action for the function to take is to have no effect.
*
* Integer constants and the memory layout of publicly exposed structs are not
* part of the ABI.
*
* @section events Events and callbacks
*
* Events are handled by callbacks. One callback can be registered per event.
* All events have a callback function type named `tox_{event}_cb` and a
* function to register it named `tox_callback_{event}`. Passing a NULL
* callback will result in no callback being registered for that event. Only
* one callback per event can be registered, so if a client needs multiple
* event listeners, it needs to implement the dispatch functionality itself.
*
* The last argument to a callback is the user data pointer. It is passed from
* tox_iterate to each callback in sequence.
*
* The user data pointer is never stored or dereferenced by any library code, so
* can be any pointer, including NULL. Callbacks must all operate on the same
* object type. In the apidsl code (tox.in.h), this is denoted with `any`. The
* `any` in tox_iterate must be the same `any` as in all callbacks. In C,
* lacking parametric polymorphism, this is a pointer to void.
*
* Old style callbacks that are registered together with a user data pointer
* receive that pointer as argument when they are called. They can each have
* their own user data pointer of their own type.
*
* @section threading Threading implications
*
* It is possible to run multiple concurrent threads with a Tox instance for
* each thread. It is also possible to run all Tox instances in the same thread.
* A common way to run Tox (multiple or single instance) is to have one thread
* running a simple tox_iterate loop, sleeping for tox_iteration_interval
* milliseconds on each iteration.
*
* If you want to access a single Tox instance from multiple threads, access
* to the instance must be synchronised. While multiple threads can concurrently
* access multiple different Tox instances, no more than one API function can
* operate on a single instance at any given time.
*
* Functions that write to variable length byte arrays will always have a size
* function associated with them. The result of this size function is only valid
* until another mutating function (one that takes a pointer to non-const Tox)
* is called. Thus, clients must ensure that no other thread calls a mutating
* function between the call to the size function and the call to the retrieval
* function.
*
* E.g. to get the current nickname, one would write
*
* @code
* size_t length = tox_self_get_name_size(tox);
* uint8_t *name = malloc(length);
* if (!name) abort();
* tox_self_get_name(tox, name);
* @endcode
*
* If any other thread calls tox_self_set_name while this thread is allocating
* memory, the length may have become invalid, and the call to
* tox_self_get_name may cause undefined behaviour.
*/
#ifndef C_TOXCORE_TOXCORE_TOX_H
#define C_TOXCORE_TOXCORE_TOX_H
#include <stdbool.h>
#include <stddef.h>
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
/** @{ @namespace tox */
#ifndef TOX_DEFINED
#define TOX_DEFINED
/**
* @brief The Tox instance type.
*
* All the state associated with a connection is held
* within the instance. Multiple instances can exist and operate concurrently.
* The maximum number of Tox instances that can exist on a single network
* device is limited. Note that this is not just a per-process limit, since the
* limiting factor is the number of usable ports on a device.
*/
typedef struct Tox Tox;
#endif /* TOX_DEFINED */
/** @{
* @name API version
*/
/**
* @brief The major version number.
*
* Incremented when the API or ABI changes in an incompatible way.
*
* The function variants of these constants return the version number of the
* library. They can be used to display the Tox library version or to check
* whether the client is compatible with the dynamically linked version of Tox.
*/
#define TOX_VERSION_MAJOR 0
uint32_t tox_version_major(void);
/**
* @brief The minor version number.
*
* Incremented when functionality is added without breaking the API or ABI.
* Set to 0 when the major version number is incremented.
*/
#define TOX_VERSION_MINOR 2
uint32_t tox_version_minor(void);
/**
* @brief The patch or revision number.
*
* Incremented when bugfixes are applied without changing any functionality or
* API or ABI.
*/
#define TOX_VERSION_PATCH 18
uint32_t tox_version_patch(void);
//!TOKSTYLE-
/**
* @brief A macro to check at preprocessing time whether the client code is
* compatible with the installed version of Tox.
*
* Leading zeros in the version number are ignored. E.g. 0.1.5 is to 0.1.4
* what 1.5 is to 1.4, that is: it can add new features, but can't break the
* API.
*/
#define TOX_VERSION_IS_API_COMPATIBLE(MAJOR, MINOR, PATCH) \
((TOX_VERSION_MAJOR > 0 && TOX_VERSION_MAJOR == MAJOR) && ( \
/* 1.x.x, 2.x.x, etc. with matching major version. */ \
TOX_VERSION_MINOR > MINOR || \
(TOX_VERSION_MINOR == MINOR && TOX_VERSION_PATCH >= PATCH) \
)) || ((TOX_VERSION_MAJOR == 0 && MAJOR == 0) && ( \
/* 0.x.x makes minor behave like major above. */ \
((TOX_VERSION_MINOR > 0 && TOX_VERSION_MINOR == MINOR) && ( \
TOX_VERSION_PATCH >= PATCH \
)) || ((TOX_VERSION_MINOR == 0 && MINOR == 0) && ( \
/* 0.0.x and 0.0.y are only compatible if x == y. */ \
TOX_VERSION_PATCH == PATCH \
)) \
))
//!TOKSTYLE+
/**
* @brief Return whether the compiled library version is compatible with the
* passed version numbers.
*/
bool tox_version_is_compatible(uint32_t major, uint32_t minor, uint32_t patch);
/**
* @brief A convenience macro to call tox_version_is_compatible with the
* currently compiling API version.
*/
#define TOX_VERSION_IS_ABI_COMPATIBLE() \
tox_version_is_compatible(TOX_VERSION_MAJOR, TOX_VERSION_MINOR, TOX_VERSION_PATCH)
/** @} */
/** @{
* @name Numeric constants
*
* The values of these are not part of the ABI. Prefer to use the function
* versions of them for code that should remain compatible with future versions
* of toxcore.
*/
/**
* @brief The size of a Tox Public Key in bytes.
*/
#define TOX_PUBLIC_KEY_SIZE 32
uint32_t tox_public_key_size(void);
/**
* @brief The size of a Tox Secret Key in bytes.
*/
#define TOX_SECRET_KEY_SIZE 32
uint32_t tox_secret_key_size(void);
/**
* @brief The size of a Tox Conference unique id in bytes.
*
* @deprecated Use TOX_CONFERENCE_ID_SIZE instead.
*/
#define TOX_CONFERENCE_UID_SIZE 32
uint32_t tox_conference_uid_size(void);
/**
* @brief The size of a Tox Conference unique id in bytes.
*/
#define TOX_CONFERENCE_ID_SIZE 32
uint32_t tox_conference_id_size(void);
/**
* @brief The size of the nospam in bytes when written in a Tox address.
*/
#define TOX_NOSPAM_SIZE (sizeof(uint32_t))
uint32_t tox_nospam_size(void);
/**
* @brief The size of a Tox address in bytes.
*
* Tox addresses are in the format
* `[Public Key (TOX_PUBLIC_KEY_SIZE bytes)][nospam (4 bytes)][checksum (2 bytes)]`.
*
* The checksum is computed over the Public Key and the nospam value. The first
* byte is an XOR of all the even bytes (0, 2, 4, ...), the second byte is an
* XOR of all the odd bytes (1, 3, 5, ...) of the Public Key and nospam.
*/
#define TOX_ADDRESS_SIZE (TOX_PUBLIC_KEY_SIZE + TOX_NOSPAM_SIZE + sizeof(uint16_t))
uint32_t tox_address_size(void);
/**
* @brief Maximum length of a nickname in bytes.
*
* @deprecated The macro will be removed in 0.3.0. Use the function instead.
*/
#define TOX_MAX_NAME_LENGTH 128
uint32_t tox_max_name_length(void);
/**
* @brief Maximum length of a status message in bytes.
*
* @deprecated The macro will be removed in 0.3.0. Use the function instead.
*/
#define TOX_MAX_STATUS_MESSAGE_LENGTH 1007
uint32_t tox_max_status_message_length(void);
/**
* @brief Maximum length of a friend request message in bytes.
*
* @deprecated The macro will be removed in 0.3.0. Use the function instead.
*/
#define TOX_MAX_FRIEND_REQUEST_LENGTH 1016
uint32_t tox_max_friend_request_length(void);
/**
* @brief Maximum length of a single message after which it should be split.
*
* @deprecated The macro will be removed in 0.3.0. Use the function instead.
*/
#define TOX_MAX_MESSAGE_LENGTH 1372
uint32_t tox_max_message_length(void);
/**
* @brief Maximum size of custom packets. TODO(iphydf): should be LENGTH?
*
* @deprecated The macro will be removed in 0.3.0. Use the function instead.
*/
#define TOX_MAX_CUSTOM_PACKET_SIZE 1373
uint32_t tox_max_custom_packet_size(void);
/**
* @brief The number of bytes in a hash generated by tox_hash.
*/
#define TOX_HASH_LENGTH 32
uint32_t tox_hash_length(void);
/**
* @brief The number of bytes in a file id.
*/
#define TOX_FILE_ID_LENGTH 32
uint32_t tox_file_id_length(void);
/**
* @brief Maximum file name length for file transfers.
*
* @deprecated The macro will be removed in 0.3.0. Use the function instead.
*/
#define TOX_MAX_FILENAME_LENGTH 255
uint32_t tox_max_filename_length(void);
/**
* @brief Maximum length of a hostname, e.g. proxy or bootstrap node names.
*
* This length does not include the NUL byte. Hostnames are NUL-terminated C
* strings, so they are 255 characters plus one NUL byte.
*
* @deprecated The macro will be removed in 0.3.0. Use the function instead.
*/
#define TOX_MAX_HOSTNAME_LENGTH 255
uint32_t tox_max_hostname_length(void);
/** @} */
/** @{
* @name Global enumerations
*/
/**
* @brief Represents the possible statuses a client can have.
*/
typedef enum Tox_User_Status {
/**
* User is online and available.
*/
TOX_USER_STATUS_NONE,
/**
* User is away. Clients can set this e.g. after a user defined
* inactivity time.
*/
TOX_USER_STATUS_AWAY,
/**
* User is busy. Signals to other clients that this client does not
* currently wish to communicate.
*/
TOX_USER_STATUS_BUSY,
} Tox_User_Status;
/**
* @brief Represents message types for tox_friend_send_message and conference
* messages.
*/
typedef enum Tox_Message_Type {
/**
* Normal text message. Similar to PRIVMSG on IRC.
*/
TOX_MESSAGE_TYPE_NORMAL,
/**
* A message describing an user action. This is similar to /me (CTCP ACTION)
* on IRC.
*/
TOX_MESSAGE_TYPE_ACTION,
} Tox_Message_Type;
/** @} */
/** @{
* @name Startup options
*/
/**
* @brief Type of proxy used to connect to TCP relays.
*/
typedef enum Tox_Proxy_Type {
/**
* Don't use a proxy.
*/
TOX_PROXY_TYPE_NONE,
/**
* HTTP proxy using CONNECT.
*/
TOX_PROXY_TYPE_HTTP,
/**
* SOCKS proxy for simple socket pipes.
*/
TOX_PROXY_TYPE_SOCKS5,
} Tox_Proxy_Type;
/**
* @brief Type of savedata to create the Tox instance from.
*/
typedef enum Tox_Savedata_Type {
/**
* No savedata.
*/
TOX_SAVEDATA_TYPE_NONE,
/**
* Savedata is one that was obtained from tox_get_savedata.
*/
TOX_SAVEDATA_TYPE_TOX_SAVE,
/**
* Savedata is a secret key of length TOX_SECRET_KEY_SIZE.
*/
TOX_SAVEDATA_TYPE_SECRET_KEY,
} Tox_Savedata_Type;
/**
* @brief Severity level of log messages.
*/
typedef enum Tox_Log_Level {
/**
* Very detailed traces including all network activity.
*/
TOX_LOG_LEVEL_TRACE,
/**
* Debug messages such as which port we bind to.
*/
TOX_LOG_LEVEL_DEBUG,
/**
* Informational log messages such as video call status changes.
*/
TOX_LOG_LEVEL_INFO,
/**
* Warnings about events_alloc inconsistency or logic errors.
*/
TOX_LOG_LEVEL_WARNING,
/**
* Severe unexpected errors caused by external or events_alloc inconsistency.
*/
TOX_LOG_LEVEL_ERROR,
} Tox_Log_Level;
/**
* @brief This event is triggered when the toxcore library logs an events_alloc message.
*
* This is mostly useful for debugging. This callback can be called from any
* function, not just tox_iterate. This means the user data lifetime must at
* least extend between registering and unregistering it or tox_kill.
*
* Other toxcore modules such as toxav may concurrently call this callback at
* any time. Thus, user code must make sure it is equipped to handle concurrent
* execution, e.g. by employing appropriate mutex locking.
*
* @param level The severity of the log message.
* @param file The source file from which the message originated.
* @param line The source line from which the message originated.
* @param func The function from which the message originated.
* @param message The log message.
* @param user_data The user data pointer passed to tox_new in options.
*/
typedef void tox_log_cb(Tox *tox, Tox_Log_Level level, const char *file, uint32_t line, const char *func,
const char *message, void *user_data);
/**
* @brief Operating system functions used by Tox.
*
* This struct is opaque and generally shouldn't be used in clients, but in
* combination with tox_private.h, it allows tests to inject non-IO (hermetic)
* versions of low level network, RNG, and time keeping functions.
*/
typedef struct Tox_System Tox_System;
/**
* @brief This struct contains all the startup options for Tox.
*
* You must tox_options_new to allocate an object of this type.
*
* WARNING: Although this struct happens to be visible in the API, it is
* effectively private. Do not allocate this yourself or access members
* directly, as it *will* break binary compatibility frequently.
*
* @deprecated The memory layout of this struct (size, alignment, and field
* order) is not part of the ABI. To remain compatible, prefer to use
* tox_options_new to allocate the object and accessor functions to set the
* members. The struct will become opaque (i.e. the definition will become
* private) in v0.3.0.
*/
struct Tox_Options {
/**
* The type of socket to create.
*
* If this is set to false, an IPv4 socket is created, which subsequently
* only allows IPv4 communication.
* If it is set to true, an IPv6 socket is created, allowing both IPv4 and
* IPv6 communication.
*/
bool ipv6_enabled;
/**
* Enable the use of UDP communication when available.
*
* Setting this to false will force Tox to use TCP only. Communications will
* need to be relayed through a TCP relay node, potentially slowing them down.
*
* If a proxy is enabled, UDP will be disabled if either toxcore or the
* proxy don't support proxying UDP messages.
*/
bool udp_enabled;
/**
* Enable local network peer discovery.
*
* Disabling this will cause Tox to not look for peers on the local network.
*/
bool local_discovery_enabled;
/**
* Enable storing DHT announcements and forwarding corresponding requests.
*
* Disabling this will cause Tox to ignore the relevant packets.
*/
bool dht_announcements_enabled;
/**
* Pass communications through a proxy.
*/
Tox_Proxy_Type proxy_type;
/**
* The IP address or DNS name of the proxy to be used.
*
* If used, this must be non-NULL and be a valid DNS name. The name must not
* exceed TOX_MAX_HOSTNAME_LENGTH characters, and be in a NUL-terminated C string
* format (TOX_MAX_HOSTNAME_LENGTH includes the NUL byte).
*
* This member is ignored (it can be NULL) if proxy_type is TOX_PROXY_TYPE_NONE.
*
* The data pointed at by this member is owned by the user, so must
* outlive the options object.
*/
const char *proxy_host;
/**
* The port to use to connect to the proxy server.
*
* Ports must be in the range (1, 65535). The value is ignored if
* proxy_type is TOX_PROXY_TYPE_NONE.
*/
uint16_t proxy_port;
/**
* The start port of the inclusive port range to attempt to use.
*
* If both start_port and end_port are 0, the default port range will be
* used: `[33445, 33545]`.
*
* If either start_port or end_port is 0 while the other is non-zero, the
* non-zero port will be the only port in the range.
*
* Having start_port > end_port will yield the same behavior as if start_port
* and end_port were swapped.
*/
uint16_t start_port;
/**
* The end port of the inclusive port range to attempt to use.
*/
uint16_t end_port;
/**
* The port to use for the TCP server (relay). If 0, the TCP server is
* disabled.
*
* Enabling it is not required for Tox to function properly.
*
* When enabled, your Tox instance can act as a TCP relay for other Tox
* instance. This leads to increased traffic, thus when writing a client
* it is recommended to enable TCP server only if the user has an option
* to disable it.
*/
uint16_t tcp_port;
/**
* Enables or disables UDP hole-punching in toxcore. (Default: enabled).
*/
bool hole_punching_enabled;
/**
* The type of savedata to load from.
*/
Tox_Savedata_Type savedata_type;
/**
* The savedata.
*
* The data pointed at by this member is owned by the user, so must
* outlive the options object.
*/
const uint8_t *savedata_data;
/**
* The length of the savedata.
*/
size_t savedata_length;
/**
* Logging callback for the new tox instance.
*/
tox_log_cb *log_callback;
/**
* User data pointer passed to the logging callback.
*/
void *log_user_data;
/**
* These options are experimental, so avoid writing code that depends on
* them. Options marked "experimental" may change their behaviour or go away
* entirely in the future, or may be renamed to something non-experimental
* if they become part of the supported API.
*/
/**
* Make public API functions thread-safe using a per-instance lock.
*
* Default: false.
*/
bool experimental_thread_safety;
/**
* Low level operating system functionality such as send/recv and random
* number generation.
*/
const Tox_System *operating_system;
};
bool tox_options_get_ipv6_enabled(const struct Tox_Options *options);
void tox_options_set_ipv6_enabled(struct Tox_Options *options, bool ipv6_enabled);
bool tox_options_get_udp_enabled(const struct Tox_Options *options);
void tox_options_set_udp_enabled(struct Tox_Options *options, bool udp_enabled);
bool tox_options_get_local_discovery_enabled(const struct Tox_Options *options);
void tox_options_set_local_discovery_enabled(struct Tox_Options *options, bool local_discovery_enabled);
bool tox_options_get_dht_announcements_enabled(const struct Tox_Options *options);
void tox_options_set_dht_announcements_enabled(struct Tox_Options *options, bool dht_announcements_enabled);
Tox_Proxy_Type tox_options_get_proxy_type(const struct Tox_Options *options);
void tox_options_set_proxy_type(struct Tox_Options *options, Tox_Proxy_Type type);
const char *tox_options_get_proxy_host(const struct Tox_Options *options);
void tox_options_set_proxy_host(struct Tox_Options *options, const char *host);
uint16_t tox_options_get_proxy_port(const struct Tox_Options *options);
void tox_options_set_proxy_port(struct Tox_Options *options, uint16_t port);
uint16_t tox_options_get_start_port(const struct Tox_Options *options);
void tox_options_set_start_port(struct Tox_Options *options, uint16_t start_port);
uint16_t tox_options_get_end_port(const struct Tox_Options *options);
void tox_options_set_end_port(struct Tox_Options *options, uint16_t end_port);
uint16_t tox_options_get_tcp_port(const struct Tox_Options *options);
void tox_options_set_tcp_port(struct Tox_Options *options, uint16_t tcp_port);
bool tox_options_get_hole_punching_enabled(const struct Tox_Options *options);
void tox_options_set_hole_punching_enabled(struct Tox_Options *options, bool hole_punching_enabled);
Tox_Savedata_Type tox_options_get_savedata_type(const struct Tox_Options *options);
void tox_options_set_savedata_type(struct Tox_Options *options, Tox_Savedata_Type type);
const uint8_t *tox_options_get_savedata_data(const struct Tox_Options *options);
void tox_options_set_savedata_data(struct Tox_Options *options, const uint8_t *data, size_t length);
size_t tox_options_get_savedata_length(const struct Tox_Options *options);
void tox_options_set_savedata_length(struct Tox_Options *options, size_t length);
tox_log_cb *tox_options_get_log_callback(const struct Tox_Options *options);
void tox_options_set_log_callback(struct Tox_Options *options, tox_log_cb *callback);
void *tox_options_get_log_user_data(const struct Tox_Options *options);
void tox_options_set_log_user_data(struct Tox_Options *options, void *user_data);
bool tox_options_get_experimental_thread_safety(const struct Tox_Options *options);
void tox_options_set_experimental_thread_safety(struct Tox_Options *options, bool experimental_thread_safety);
const Tox_System *tox_options_get_operating_system(const struct Tox_Options *options);
void tox_options_set_operating_system(struct Tox_Options *options, const Tox_System *operating_system);
/**
* @brief Initialises a Tox_Options object with the default options.
*
* The result of this function is independent of the original options. All
* values will be overwritten, no values will be read (so it is permissible
* to pass an uninitialised object).
*
* If options is NULL, this function has no effect.
*
* @param options An options object to be filled with default options.
*/
void tox_options_default(struct Tox_Options *options);
typedef enum Tox_Err_Options_New {
/**
* The function returned successfully.
*/
TOX_ERR_OPTIONS_NEW_OK,
/**
* The function failed to allocate enough memory for the options struct.
*/
TOX_ERR_OPTIONS_NEW_MALLOC,
} Tox_Err_Options_New;
/**
* @brief Allocates a new Tox_Options object and initialises it with the default
* options.
*
* This function can be used to preserve long term ABI compatibility by
* giving the responsibility of allocation and deallocation to the Tox library.
*
* Objects returned from this function must be freed using the tox_options_free
* function.
*
* @return A new Tox_Options object with default options or NULL on failure.
*/
struct Tox_Options *tox_options_new(Tox_Err_Options_New *error);
/**
* @brief Releases all resources associated with an options objects.
*
* Passing a pointer that was not returned by tox_options_new results in
* undefined behaviour.
*/
void tox_options_free(struct Tox_Options *options);
/** @} */
/** @{
* @name Creation and destruction
*/
typedef enum Tox_Err_New {
/**
* The function returned successfully.
*/
TOX_ERR_NEW_OK,
/**
* One of the arguments to the function was NULL when it was not expected.
*/
TOX_ERR_NEW_NULL,
/**
* The function was unable to allocate enough memory to store the events_alloc
* structures for the Tox object.
*/
TOX_ERR_NEW_MALLOC,
/**
* The function was unable to bind to a port. This may mean that all ports
* have already been bound, e.g. by other Tox instances, or it may mean
* a permission error. You may be able to gather more information from errno.
*/
TOX_ERR_NEW_PORT_ALLOC,
/**
* proxy_type was invalid.
*/
TOX_ERR_NEW_PROXY_BAD_TYPE,
/**
* proxy_type was valid but the proxy_host passed had an invalid format
* or was NULL.
*/
TOX_ERR_NEW_PROXY_BAD_HOST,
/**
* proxy_type was valid, but the proxy_port was invalid.
*/
TOX_ERR_NEW_PROXY_BAD_PORT,
/**
* The proxy address passed could not be resolved.
*/
TOX_ERR_NEW_PROXY_NOT_FOUND,
/**
* The byte array to be loaded contained an encrypted save.
*/
TOX_ERR_NEW_LOAD_ENCRYPTED,
/**
* The data format was invalid. This can happen when loading data that was
* saved by an older version of Tox, or when the data has been corrupted.
* When loading from badly formatted data, some data may have been loaded,
* and the rest is discarded. Passing an invalid length parameter also
* causes this error.
*/
TOX_ERR_NEW_LOAD_BAD_FORMAT,
} Tox_Err_New;
/**
* @brief Creates and initialises a new Tox instance with the options passed.
*
* This function will bring the instance into a valid state. Running the event
* loop with a new instance will operate correctly.
*
* If loading failed or succeeded only partially, the new or partially loaded
* instance is returned and an error code is set.
*
* @param options An options object as described above. If this parameter is
* NULL, the default options are used.
*
* @see tox_iterate for the event loop.
*
* @return A new Tox instance pointer on success or NULL on failure.
*/
Tox *tox_new(const struct Tox_Options *options, Tox_Err_New *error);
/**
* @brief Releases all resources associated with the Tox instance and
* disconnects from the network.
*
* After calling this function, the Tox pointer becomes invalid. No other
* functions can be called, and the pointer value can no longer be read.
*/
void tox_kill(Tox *tox);
/**
* @brief Calculates the number of bytes required to store the tox instance with
* tox_get_savedata.
*
* This function cannot fail. The result is always greater than 0.
*
* @see threading for concurrency implications.
*/
size_t tox_get_savedata_size(const Tox *tox);
/**
* @brief Store all information associated with the tox instance to a byte array.
*
* @param savedata A memory region large enough to store the tox instance
* data. Call tox_get_savedata_size to find the number of bytes required. If this parameter
* is NULL, this function has no effect.
*/
void tox_get_savedata(const Tox *tox, uint8_t *savedata);
/** @} */
/** @{
* @name Connection lifecycle and event loop
*/
typedef enum Tox_Err_Bootstrap {
/**
* The function returned successfully.
*/
TOX_ERR_BOOTSTRAP_OK,
/**
* One of the arguments to the function was NULL when it was not expected.
*/
TOX_ERR_BOOTSTRAP_NULL,
/**
* The hostname could not be resolved to an IP address, the IP address
* passed was invalid, or the function failed to send the initial request
* packet to the bootstrap node or TCP relay.
*/
TOX_ERR_BOOTSTRAP_BAD_HOST,
/**
* The port passed was invalid. The valid port range is (1, 65535).
*/
TOX_ERR_BOOTSTRAP_BAD_PORT,
} Tox_Err_Bootstrap;
/**
* @brief Sends a "get nodes" request to the given bootstrap node with IP, port,
* and public key to setup connections.
*
* This function will attempt to connect to the node using UDP. You must use
* this function even if Tox_Options.udp_enabled was set to false.
*
* @param host The hostname or IP address (IPv4 or IPv6) of the node. Must be
* at most TOX_MAX_HOSTNAME_LENGTH chars, including the NUL byte.
* @param port The port on the host on which the bootstrap Tox instance is
* listening.
* @param public_key The long term public key of the bootstrap node
* (TOX_PUBLIC_KEY_SIZE bytes).
* @return true on success.
*/
bool tox_bootstrap(Tox *tox, const char *host, uint16_t port, const uint8_t *public_key, Tox_Err_Bootstrap *error);
/**
* @brief Adds additional host:port pair as TCP relay.
*
* This function can be used to initiate TCP connections to different ports on
* the same bootstrap node, or to add TCP relays without using them as
* bootstrap nodes.
*
* @param host The hostname or IP address (IPv4 or IPv6) of the TCP relay.
* Must be at most TOX_MAX_HOSTNAME_LENGTH chars, including the NUL byte.
* @param port The port on the host on which the TCP relay is listening.
* @param public_key The long term public key of the TCP relay
* (TOX_PUBLIC_KEY_SIZE bytes).
* @return true on success.
*/
bool tox_add_tcp_relay(Tox *tox, const char *host, uint16_t port, const uint8_t *public_key, Tox_Err_Bootstrap *error);
/**
* @brief Protocols that can be used to connect to the network or friends.
*/
typedef enum Tox_Connection {
/**
* @brief There is no connection.
*
* This instance, or the friend the state change is about, is now offline.
*/
TOX_CONNECTION_NONE,
/**
* @brief A TCP connection has been established.
*
* For the own instance, this means it is connected through a TCP relay,
* only. For a friend, this means that the connection to that particular
* friend goes through a TCP relay.
*/
TOX_CONNECTION_TCP,
/**
* @brief A UDP connection has been established.
*
* For the own instance, this means it is able to send UDP packets to DHT
* nodes, but may still be connected to a TCP relay. For a friend, this
* means that the connection to that particular friend was built using
* direct UDP packets.
*/
TOX_CONNECTION_UDP,
} Tox_Connection;
/**
* @brief Return whether we are connected to the DHT.
*
* The return value is equal to the last value received through the
* `self_connection_status` callback.
*
* @deprecated This getter is deprecated. Use the event and store the status
* in the client state.
*/
Tox_Connection tox_self_get_connection_status(const Tox *tox);
/**
* @param connection_status Whether we are connected to the DHT.
*/
typedef void tox_self_connection_status_cb(Tox *tox, Tox_Connection connection_status, void *user_data);
/**
* @brief Set the callback for the `self_connection_status` event.
*
* Pass NULL to unset.
*
* This event is triggered whenever there is a change in the DHT connection
* state. When disconnected, a client may choose to call tox_bootstrap again, to
* reconnect to the DHT. Note that this state may frequently change for short
* amounts of time. Clients should therefore not immediately bootstrap on
* receiving a disconnect.
*
* TODO(iphydf): how long should a client wait before bootstrapping again?
*/
void tox_callback_self_connection_status(Tox *tox, tox_self_connection_status_cb *callback);
/**
* @brief Return the time in milliseconds before `tox_iterate()` should be called again
* for optimal performance.
*/
uint32_t tox_iteration_interval(const Tox *tox);
/**
* @brief The main loop that needs to be run in intervals of `tox_iteration_interval()`
* milliseconds.
*/
void tox_iterate(Tox *tox, void *user_data);
/** @} */
/** @{
* @name Internal client information (Tox address/id)
*/
/**
* @brief Writes the Tox friend address of the client to a byte array.
*
* The address is not in human-readable format. If a client wants to display
* the address, formatting is required.
*
* @param address A memory region of at least TOX_ADDRESS_SIZE bytes. If this
* parameter is NULL, this function has no effect.
* @see TOX_ADDRESS_SIZE for the address format.
*/
void tox_self_get_address(const Tox *tox, uint8_t *address);
/**
* @brief Set the 4-byte nospam part of the address.
*
* This value is expected in host byte order. I.e. 0x12345678 will form the
* bytes `[12, 34, 56, 78]` in the nospam part of the Tox friend address.
*
* @param nospam Any 32 bit unsigned integer.
*/
void tox_self_set_nospam(Tox *tox, uint32_t nospam);
/**
* @brief Get the 4-byte nospam part of the address.
*
* This value is returned in host byte order.
*/
uint32_t tox_self_get_nospam(const Tox *tox);
/**
* @brief Copy the Tox Public Key (long term) from the Tox object.
*
* @param public_key A memory region of at least TOX_PUBLIC_KEY_SIZE bytes. If
* this parameter is NULL, this function has no effect.
*/
void tox_self_get_public_key(const Tox *tox, uint8_t *public_key);
/**
* @brief Copy the Tox Secret Key from the Tox object.
*
* @param secret_key A memory region of at least TOX_SECRET_KEY_SIZE bytes. If
* this parameter is NULL, this function has no effect.
*/
void tox_self_get_secret_key(const Tox *tox, uint8_t *secret_key);
/** @} */
/** @{
* @name User-visible client information (nickname/status)
*/
/**
* @brief Common error codes for all functions that set a piece of user-visible
* client information.
*/
typedef enum Tox_Err_Set_Info {
/**
* The function returned successfully.
*/
TOX_ERR_SET_INFO_OK,
/**
* One of the arguments to the function was NULL when it was not expected.
*/
TOX_ERR_SET_INFO_NULL,
/**
* Information length exceeded maximum permissible size.
*/
TOX_ERR_SET_INFO_TOO_LONG,
} Tox_Err_Set_Info;
/**
* @brief Set the nickname for the Tox client.
*
* Nickname length cannot exceed TOX_MAX_NAME_LENGTH. If length is 0, the name
* parameter is ignored (it can be NULL), and the nickname is set back to empty.
*
* @param name A byte array containing the new nickname.
* @param length The size of the name byte array.
*
* @return true on success.
*/
bool tox_self_set_name(Tox *tox, const uint8_t *name, size_t length, Tox_Err_Set_Info *error);
/**
* @brief Return the length of the current nickname as passed to tox_self_set_name.
*
* If no nickname was set before calling this function, the name is empty,
* and this function returns 0.
*
* @see threading for concurrency implications.
*/
size_t tox_self_get_name_size(const Tox *tox);
/**
* @brief Write the nickname set by tox_self_set_name to a byte array.
*
* If no nickname was set before calling this function, the name is empty,
* and this function has no effect.
*
* Call tox_self_get_name_size to find out how much memory to allocate for
* the result.
*
* @param name A valid memory location large enough to hold the nickname.
* If this parameter is NULL, the function has no effect.
*/
void tox_self_get_name(const Tox *tox, uint8_t *name);
/**
* @brief Set the client's status message.
*
* Status message length cannot exceed TOX_MAX_STATUS_MESSAGE_LENGTH. If
* length is 0, the status parameter is ignored (it can be NULL), and the
* user status is set back to empty.
*/
bool tox_self_set_status_message(Tox *tox, const uint8_t *status_message, size_t length, Tox_Err_Set_Info *error);
/**
* @brief Return the length of the current status message as passed to tox_self_set_status_message.
*
* If no status message was set before calling this function, the status
* is empty, and this function returns 0.
*
* @see threading for concurrency implications.
*/
size_t tox_self_get_status_message_size(const Tox *tox);
/**
* @brief Write the status message set by tox_self_set_status_message to a byte array.
*
* If no status message was set before calling this function, the status is
* empty, and this function has no effect.
*
* Call tox_self_get_status_message_size to find out how much memory to allocate for
* the result.
*
* @param status_message A valid memory location large enough to hold the
* status message. If this parameter is NULL, the function has no effect.
*/
void tox_self_get_status_message(const Tox *tox, uint8_t *status_message);
/**
* @brief Set the client's user status.
*
* @param status One of the user statuses listed in the enumeration above.
*/
void tox_self_set_status(Tox *tox, Tox_User_Status status);
/**
* @brief Returns the client's user status.
*/
Tox_User_Status tox_self_get_status(const Tox *tox);
/** @} */
/** @{
* @name Friend list management
*/
typedef enum Tox_Err_Friend_Add {
/**
* The function returned successfully.
*/
TOX_ERR_FRIEND_ADD_OK,
/**
* One of the arguments to the function was NULL when it was not expected.
*/
TOX_ERR_FRIEND_ADD_NULL,
/**
* The length of the friend request message exceeded
* TOX_MAX_FRIEND_REQUEST_LENGTH.
*/
TOX_ERR_FRIEND_ADD_TOO_LONG,
/**
* The friend request message was empty. This, and the TOO_LONG code will
* never be returned from tox_friend_add_norequest.
*/
TOX_ERR_FRIEND_ADD_NO_MESSAGE,
/**
* The friend address belongs to the sending client.
*/
TOX_ERR_FRIEND_ADD_OWN_KEY,
/**
* A friend request has already been sent, or the address belongs to a friend
* that is already on the friend list.
*/
TOX_ERR_FRIEND_ADD_ALREADY_SENT,
/**
* The friend address checksum failed.
*/
TOX_ERR_FRIEND_ADD_BAD_CHECKSUM,
/**
* The friend was already there, but the nospam value was different.
*/
TOX_ERR_FRIEND_ADD_SET_NEW_NOSPAM,
/**
* A memory allocation failed when trying to increase the friend list size.
*/
TOX_ERR_FRIEND_ADD_MALLOC,
} Tox_Err_Friend_Add;
/**
* @brief Add a friend to the friend list and send a friend request.
*
* A friend request message must be at least 1 byte long and at most
* TOX_MAX_FRIEND_REQUEST_LENGTH.
*
* Friend numbers are unique identifiers used in all functions that operate on
* friends. Once added, a friend number is stable for the lifetime of the Tox
* object. After saving the state and reloading it, the friend numbers may not
* be the same as before. Deleting a friend creates a gap in the friend number
* set, which is filled by the next adding of a friend. Any pattern in friend
* numbers should not be relied on.
*
* If more than INT32_MAX friends are added, this function causes undefined
* behaviour.
*
* @param address The address of the friend (returned by tox_self_get_address of
* the friend you wish to add) it must be TOX_ADDRESS_SIZE bytes.
* @param message The message that will be sent along with the friend request.
* @param length The length of the data byte array.
*
* @return the friend number on success, an unspecified value on failure.
*/
uint32_t tox_friend_add(Tox *tox, const uint8_t *address, const uint8_t *message, size_t length,
Tox_Err_Friend_Add *error);
/**
* @brief Add a friend without sending a friend request.
*
* This function is used to add a friend in response to a friend request. If the
* client receives a friend request, it can be reasonably sure that the other
* client added this client as a friend, eliminating the need for a friend
* request.
*
* This function is also useful in a situation where both instances are
* controlled by the same entity, so that this entity can perform the mutual
* friend adding. In this case, there is no need for a friend request, either.
*
* @param public_key A byte array of length TOX_PUBLIC_KEY_SIZE containing the
* Public Key (not the Address) of the friend to add.
*
* @return the friend number on success, an unspecified value on failure.
* @see tox_friend_add for a more detailed description of friend numbers.
*/
uint32_t tox_friend_add_norequest(Tox *tox, const uint8_t *public_key, Tox_Err_Friend_Add *error);
typedef enum Tox_Err_Friend_Delete {
/**
* The function returned successfully.
*/
TOX_ERR_FRIEND_DELETE_OK,
/**
* There was no friend with the given friend number. No friends were deleted.
*/
TOX_ERR_FRIEND_DELETE_FRIEND_NOT_FOUND,
} Tox_Err_Friend_Delete;
/**
* @brief Remove a friend from the friend list.
*
* This does not notify the friend of their deletion. After calling this
* function, this client will appear offline to the friend and no communication
* can occur between the two.
*
* @param friend_number Friend number for the friend to be deleted.
*
* @return true on success.
*/
bool tox_friend_delete(Tox *tox, uint32_t friend_number, Tox_Err_Friend_Delete *error);
/** @} */
/** @{
* @name Friend list queries
*/
typedef enum Tox_Err_Friend_By_Public_Key {
/**
* The function returned successfully.
*/
TOX_ERR_FRIEND_BY_PUBLIC_KEY_OK,
/**
* One of the arguments to the function was NULL when it was not expected.
*/
TOX_ERR_FRIEND_BY_PUBLIC_KEY_NULL,
/**
* No friend with the given Public Key exists on the friend list.
*/
TOX_ERR_FRIEND_BY_PUBLIC_KEY_NOT_FOUND,
} Tox_Err_Friend_By_Public_Key;
/**
* @brief Return the friend number associated with that Public Key.
*
* @return the friend number on success, an unspecified value on failure.
* @param public_key A byte array containing the Public Key.
*/
uint32_t tox_friend_by_public_key(const Tox *tox, const uint8_t *public_key, Tox_Err_Friend_By_Public_Key *error);
/**
* @brief Checks if a friend with the given friend number exists and returns true if
* it does.
*/
bool tox_friend_exists(const Tox *tox, uint32_t friend_number);
/**
* @brief Return the number of friends on the friend list.
*
* This function can be used to determine how much memory to allocate for
* tox_self_get_friend_list.
*/
size_t tox_self_get_friend_list_size(const Tox *tox);
/**
* @brief Copy a list of valid friend numbers into an array.
*
* Call tox_self_get_friend_list_size to determine the number of elements to allocate.
*
* @param friend_list A memory region with enough space to hold the friend
* list. If this parameter is NULL, this function has no effect.
*/
void tox_self_get_friend_list(const Tox *tox, uint32_t *friend_list);
typedef enum Tox_Err_Friend_Get_Public_Key {
/**
* The function returned successfully.
*/
TOX_ERR_FRIEND_GET_PUBLIC_KEY_OK,
/**
* No friend with the given number exists on the friend list.
*/
TOX_ERR_FRIEND_GET_PUBLIC_KEY_FRIEND_NOT_FOUND,
} Tox_Err_Friend_Get_Public_Key;
/**
* @brief Copies the Public Key associated with a given friend number to a byte array.
*
* @param friend_number The friend number you want the Public Key of.
* @param public_key A memory region of at least TOX_PUBLIC_KEY_SIZE bytes. If
* this parameter is NULL, this function has no effect.
*
* @return true on success.
*/
bool tox_friend_get_public_key(const Tox *tox, uint32_t friend_number, uint8_t *public_key,
Tox_Err_Friend_Get_Public_Key *error);
typedef enum Tox_Err_Friend_Get_Last_Online {
/**
* The function returned successfully.
*/
TOX_ERR_FRIEND_GET_LAST_ONLINE_OK,
/**
* No friend with the given number exists on the friend list.
*/
TOX_ERR_FRIEND_GET_LAST_ONLINE_FRIEND_NOT_FOUND,
} Tox_Err_Friend_Get_Last_Online;
/**
* @brief Return a unix-time timestamp of the last time the friend associated with a given
* friend number was seen online.
*
* This function will return UINT64_MAX on error.
*
* @param friend_number The friend number you want to query.
*/
uint64_t tox_friend_get_last_online(const Tox *tox, uint32_t friend_number, Tox_Err_Friend_Get_Last_Online *error);
/** @} */
/** @{
* @name Friend-specific state queries (can also be received through callbacks)
*/
/**
* @brief Common error codes for friend state query functions.
*/
typedef enum Tox_Err_Friend_Query {
/**
* The function returned successfully.
*/
TOX_ERR_FRIEND_QUERY_OK,
/**
* The pointer parameter for storing the query result (name, message) was
* NULL. Unlike the `_self_` variants of these functions, which have no effect
* when a parameter is NULL, these functions return an error in that case.
*/
TOX_ERR_FRIEND_QUERY_NULL,
/**
* The friend_number did not designate a valid friend.
*/
TOX_ERR_FRIEND_QUERY_FRIEND_NOT_FOUND,
} Tox_Err_Friend_Query;
/**
* @brief Return the length of the friend's name.
*
* If the friend number is invalid, the return value is unspecified.
*
* The return value is equal to the `length` argument received by the last
* `friend_name` callback.
*/
size_t tox_friend_get_name_size(const Tox *tox, uint32_t friend_number, Tox_Err_Friend_Query *error);
/**
* @brief Write the name of the friend designated by the given friend number to a byte
* array.
*
* Call tox_friend_get_name_size to determine the allocation size for the `name`
* parameter.
*
* The data written to `name` is equal to the data received by the last
* `friend_name` callback.
*
* @param name A valid memory region large enough to store the friend's name.
*
* @return true on success.
*/
bool tox_friend_get_name(const Tox *tox, uint32_t friend_number, uint8_t *name, Tox_Err_Friend_Query *error);
/**
* @param friend_number The friend number of the friend whose name changed.
* @param name A byte array containing the same data as
* tox_friend_get_name would write to its `name` parameter.
* @param length A value equal to the return value of
* tox_friend_get_name_size.
*/
typedef void tox_friend_name_cb(Tox *tox, uint32_t friend_number, const uint8_t *name, size_t length, void *user_data);
/**
* @brief Set the callback for the `friend_name` event.
*
* Pass NULL to unset.
*
* This event is triggered when a friend changes their name.
*/
void tox_callback_friend_name(Tox *tox, tox_friend_name_cb *callback);
/**
* @brief Return the length of the friend's status message.
*
* If the friend number isinvalid, the return value is SIZE_MAX.
*/
size_t tox_friend_get_status_message_size(const Tox *tox, uint32_t friend_number, Tox_Err_Friend_Query *error);
/**
* @brief Write the status message of the friend designated by the given friend number to a byte
* array.
*
* Call tox_friend_get_status_message_size to determine the allocation size for the `status_message`
* parameter.
*
* The data written to `status_message` is equal to the data received by the last
* `friend_status_message` callback.
*
* @param status_message A valid memory region large enough to store the friend's status message.
*/
bool tox_friend_get_status_message(const Tox *tox, uint32_t friend_number, uint8_t *status_message,
Tox_Err_Friend_Query *error);
/**
* @param friend_number The friend number of the friend whose status message
* changed.
* @param message A byte array containing the same data as
* tox_friend_get_status_message would write to its `status_message` parameter.
* @param length A value equal to the return value of
* tox_friend_get_status_message_size.
*/
typedef void tox_friend_status_message_cb(Tox *tox, uint32_t friend_number, const uint8_t *message, size_t length,
void *user_data);
/**
* @brief Set the callback for the `friend_status_message` event.
*
* Pass NULL to unset.
*
* This event is triggered when a friend changes their status message.
*/
void tox_callback_friend_status_message(Tox *tox, tox_friend_status_message_cb *callback);
/**
* @brief Return the friend's user status (away/busy/...).
*
* If the friend number is invalid, the return value is unspecified.
*
* The status returned is equal to the last status received through the
* `friend_status` callback.
*
* @deprecated This getter is deprecated. Use the event and store the status
* in the client state.
*/
Tox_User_Status tox_friend_get_status(const Tox *tox, uint32_t friend_number, Tox_Err_Friend_Query *error);
/**
* @param friend_number The friend number of the friend whose user status
* changed.
* @param status The new user status.
*/
typedef void tox_friend_status_cb(Tox *tox, uint32_t friend_number, Tox_User_Status status, void *user_data);
/**
* @brief Set the callback for the `friend_status` event.
*
* Pass NULL to unset.
*
* This event is triggered when a friend changes their user status.
*/
void tox_callback_friend_status(Tox *tox, tox_friend_status_cb *callback);
/**
* @brief Check whether a friend is currently connected to this client.
*
* The result of this function is equal to the last value received by the
* `friend_connection_status` callback.
*
* @param friend_number The friend number for which to query the connection
* status.
*
* @return the friend's connection status as it was received through the
* `friend_connection_status` event.
*
* @deprecated This getter is deprecated. Use the event and store the status
* in the client state.
*/
Tox_Connection tox_friend_get_connection_status(const Tox *tox, uint32_t friend_number, Tox_Err_Friend_Query *error);
/**
* @param friend_number The friend number of the friend whose connection status
* changed.
* @param connection_status The result of calling
* tox_friend_get_connection_status on the passed friend_number.
*/
typedef void tox_friend_connection_status_cb(Tox *tox, uint32_t friend_number, Tox_Connection connection_status,
void *user_data);
/**
* @brief Set the callback for the `friend_connection_status` event.
*
* Pass NULL to unset.
*
* This event is triggered when a friend goes offline after having been online,
* or when a friend goes online.
*
* This callback is not called when adding friends. It is assumed that when
* adding friends, their connection status is initially offline.
*/
void tox_callback_friend_connection_status(Tox *tox, tox_friend_connection_status_cb *callback);
/**
* @brief Check whether a friend is currently typing a message.
*
* @param friend_number The friend number for which to query the typing status.
*
* @return true if the friend is typing.
* @return false if the friend is not typing, or the friend number was
* invalid. Inspect the error code to determine which case it is.
*
* @deprecated This getter is deprecated. Use the event and store the status
* in the client state.
*/
bool tox_friend_get_typing(const Tox *tox, uint32_t friend_number, Tox_Err_Friend_Query *error);
/**
* @param friend_number The friend number of the friend who started or stopped
* typing.
* @param typing The result of calling tox_friend_get_typing on the passed
* friend_number.
*/
typedef void tox_friend_typing_cb(Tox *tox, uint32_t friend_number, bool typing, void *user_data);
/**
* @brief Set the callback for the `friend_typing` event.
*
* Pass NULL to unset.
*
* This event is triggered when a friend starts or stops typing.
*/
void tox_callback_friend_typing(Tox *tox, tox_friend_typing_cb *callback);
/** @} */
/** @{
* @name Sending private messages
*/
typedef enum Tox_Err_Set_Typing {
/**
* The function returned successfully.
*/
TOX_ERR_SET_TYPING_OK,
/**
* The friend number did not designate a valid friend.
*/
TOX_ERR_SET_TYPING_FRIEND_NOT_FOUND,
} Tox_Err_Set_Typing;
/**
* @brief Set the client's typing status for a friend.
*
* The client is responsible for turning it on or off.
*
* @param friend_number The friend to which the client is typing a message.
* @param typing The typing status. True means the client is typing.
*
* @return true on success.
*/
bool tox_self_set_typing(Tox *tox, uint32_t friend_number, bool typing, Tox_Err_Set_Typing *error);
typedef enum Tox_Err_Friend_Send_Message {
/**
* The function returned successfully.
*/
TOX_ERR_FRIEND_SEND_MESSAGE_OK,
/**
* One of the arguments to the function was NULL when it was not expected.
*/
TOX_ERR_FRIEND_SEND_MESSAGE_NULL,
/**
* The friend number did not designate a valid friend.
*/
TOX_ERR_FRIEND_SEND_MESSAGE_FRIEND_NOT_FOUND,
/**
* This client is currently not connected to the friend.
*/
TOX_ERR_FRIEND_SEND_MESSAGE_FRIEND_NOT_CONNECTED,
/**
* An allocation error occurred while increasing the send queue size.
*/
TOX_ERR_FRIEND_SEND_MESSAGE_SENDQ,
/**
* Message length exceeded TOX_MAX_MESSAGE_LENGTH.
*/
TOX_ERR_FRIEND_SEND_MESSAGE_TOO_LONG,
/**
* Attempted to send a zero-length message.
*/
TOX_ERR_FRIEND_SEND_MESSAGE_EMPTY,
} Tox_Err_Friend_Send_Message;
/**
* @brief Send a text chat message to an online friend.
*
* This function creates a chat message packet and pushes it into the send
* queue.
*
* The message length may not exceed TOX_MAX_MESSAGE_LENGTH. Larger messages
* must be split by the client and sent as separate messages. Other clients can
* then reassemble the fragments. Messages may not be empty.
*
* The return value of this function is the message ID. If a read receipt is
* received, the triggered `friend_read_receipt` event will be passed this message ID.
*
* Message IDs are unique per friend. The first message ID is 0. Message IDs are
* incremented by 1 each time a message is sent. If UINT32_MAX messages were
* sent, the next message ID is 0.
*
* @param type Message type (normal, action, ...).
* @param friend_number The friend number of the friend to send the message to.
* @param message A non-NULL pointer to the first element of a byte array
* containing the message text.
* @param length Length of the message to be sent.
*/
uint32_t tox_friend_send_message(Tox *tox, uint32_t friend_number, Tox_Message_Type type, const uint8_t *message,
size_t length, Tox_Err_Friend_Send_Message *error);
/**
* @param friend_number The friend number of the friend who received the message.
* @param message_id The message ID as returned from tox_friend_send_message
* corresponding to the message sent.
*/
typedef void tox_friend_read_receipt_cb(Tox *tox, uint32_t friend_number, uint32_t message_id, void *user_data);
/**
* @brief Set the callback for the `friend_read_receipt` event.
*
* Pass NULL to unset.
*
* This event is triggered when the friend receives the message sent with
* tox_friend_send_message with the corresponding message ID.
*/
void tox_callback_friend_read_receipt(Tox *tox, tox_friend_read_receipt_cb *callback);
/** @} */
/** @{
* @name Receiving private messages and friend requests
*/
/**
* @param public_key The Public Key of the user who sent the friend request.
* @param message The message they sent along with the request.
* @param length The size of the message byte array.
*/
typedef void tox_friend_request_cb(Tox *tox, const uint8_t *public_key, const uint8_t *message, size_t length,
void *user_data);
/**
* @brief Set the callback for the `friend_request` event.
*
* Pass NULL to unset.
*
* This event is triggered when a friend request is received.
*/
void tox_callback_friend_request(Tox *tox, tox_friend_request_cb *callback);
/**
* @param friend_number The friend number of the friend who sent the message.
* @param message The message data they sent.
* @param length The size of the message byte array.
*/
typedef void tox_friend_message_cb(Tox *tox, uint32_t friend_number, Tox_Message_Type type, const uint8_t *message,
size_t length, void *user_data);
/**
* @brief Set the callback for the `friend_message` event.
*
* Pass NULL to unset.
*
* This event is triggered when a message from a friend is received.
*/
void tox_callback_friend_message(Tox *tox, tox_friend_message_cb *callback);
/** @} */
/** @{
* @name File transmission: common between sending and receiving
*/
/**
* @brief Generates a cryptographic hash of the given data.
*
* This function may be used by clients for any purpose, but is provided
* primarily for validating cached avatars. This use is highly recommended to
* avoid unnecessary avatar updates.
*
* If hash is NULL or data is NULL while length is not 0 the function returns false,
* otherwise it returns true.
*
* This function is a wrapper to events_alloc message-digest functions.
*
* @param hash A valid memory location the hash data. It must be at least
* TOX_HASH_LENGTH bytes in size.
* @param data Data to be hashed or NULL.
* @param length Size of the data array or 0.
*
* @return true if hash was not NULL.
*/
bool tox_hash(uint8_t *hash, const uint8_t *data, size_t length);
/**
* @brief A list of pre-defined file kinds.
*
* Toxcore itself does not behave differently for different file kinds. These
* are a hint to the client telling it what use the sender intended for the
* file. The `kind` parameter in the send function and recv callback are
* `uint32_t`, not Tox_File_Kind, because clients can invent their own file
* kind. Unknown file kinds should be treated as TOX_FILE_KIND_DATA.
*/
enum Tox_File_Kind {
/**
* Arbitrary file data. Clients can choose to handle it based on the file name
* or magic or any other way they choose.
*/
TOX_FILE_KIND_DATA,
/**
* Avatar file_id. This consists of tox_hash(image).
* Avatar data. This consists of the image data.
*
* Avatars can be sent at any time the client wishes. Generally, a client will
* send the avatar to a friend when that friend comes online, and to all
* friends when the avatar changed. A client can save some traffic by
* remembering which friend received the updated avatar already and only send
* it if the friend has an out of date avatar.
*
* Clients who receive avatar send requests can reject it (by sending
* TOX_FILE_CONTROL_CANCEL before any other controls), or accept it (by
* sending TOX_FILE_CONTROL_RESUME). The file_id of length TOX_HASH_LENGTH bytes
* (same length as TOX_FILE_ID_LENGTH) will contain the hash. A client can compare
* this hash with a saved hash and send TOX_FILE_CONTROL_CANCEL to terminate the avatar
* transfer if it matches.
*
* When file_size is set to 0 in the transfer request it means that the client
* has no avatar.
*/
TOX_FILE_KIND_AVATAR,
};
typedef enum Tox_File_Control {
/**
* Sent by the receiving side to accept a file send request. Also sent after a
* TOX_FILE_CONTROL_PAUSE command to continue sending or receiving.
*/
TOX_FILE_CONTROL_RESUME,
/**
* Sent by clients to pause the file transfer. The initial state of a file
* transfer is always paused on the receiving side and running on the sending
* side. If both the sending and receiving side pause the transfer, then both
* need to send TOX_FILE_CONTROL_RESUME for the transfer to resume.
*/
TOX_FILE_CONTROL_PAUSE,
/**
* Sent by the receiving side to reject a file send request before any other
* commands are sent. Also sent by either side to terminate a file transfer.
*/
TOX_FILE_CONTROL_CANCEL,
} Tox_File_Control;
typedef enum Tox_Err_File_Control {
/**
* The function returned successfully.
*/
TOX_ERR_FILE_CONTROL_OK,
/**
* The friend_number passed did not designate a valid friend.
*/
TOX_ERR_FILE_CONTROL_FRIEND_NOT_FOUND,
/**
* This client is currently not connected to the friend.
*/
TOX_ERR_FILE_CONTROL_FRIEND_NOT_CONNECTED,
/**
* No file transfer with the given file number was found for the given friend.
*/
TOX_ERR_FILE_CONTROL_NOT_FOUND,
/**
* A RESUME control was sent, but the file transfer is running normally.
*/
TOX_ERR_FILE_CONTROL_NOT_PAUSED,
/**
* A RESUME control was sent, but the file transfer was paused by the other
* party. Only the party that paused the transfer can resume it.
*/
TOX_ERR_FILE_CONTROL_DENIED,
/**
* A PAUSE control was sent, but the file transfer was already paused.
*/
TOX_ERR_FILE_CONTROL_ALREADY_PAUSED,
/**
* Packet queue is full.
*/
TOX_ERR_FILE_CONTROL_SENDQ,
} Tox_Err_File_Control;
/**
* @brief Sends a file control command to a friend for a given file transfer.
*
* @param friend_number The friend number of the friend the file is being
* transferred to or received from.
* @param file_number The friend-specific identifier for the file transfer.
* @param control The control command to send.
*
* @return true on success.
*/
bool tox_file_control(Tox *tox, uint32_t friend_number, uint32_t file_number, Tox_File_Control control,
Tox_Err_File_Control *error);
/**
* @brief When receiving TOX_FILE_CONTROL_CANCEL, the client should release the
* resources associated with the file number and consider the transfer failed.
*
* @param friend_number The friend number of the friend who is sending the file.
* @param file_number The friend-specific file number the data received is
* associated with.
* @param control The file control command received.
*/
typedef void tox_file_recv_control_cb(Tox *tox, uint32_t friend_number, uint32_t file_number, Tox_File_Control control,
void *user_data);
/**
* @brief Set the callback for the `file_recv_control` event.
*
* Pass NULL to unset.
*
* This event is triggered when a file control command is received from a
* friend.
*/
void tox_callback_file_recv_control(Tox *tox, tox_file_recv_control_cb *callback);
typedef enum Tox_Err_File_Seek {
/**
* The function returned successfully.
*/
TOX_ERR_FILE_SEEK_OK,
/**
* The friend_number passed did not designate a valid friend.
*/
TOX_ERR_FILE_SEEK_FRIEND_NOT_FOUND,
/**
* This client is currently not connected to the friend.
*/
TOX_ERR_FILE_SEEK_FRIEND_NOT_CONNECTED,
/**
* No file transfer with the given file number was found for the given friend.
*/
TOX_ERR_FILE_SEEK_NOT_FOUND,
/**
* File was not in a state where it could be seeked.
*/
TOX_ERR_FILE_SEEK_DENIED,
/**
* Seek position was invalid
*/
TOX_ERR_FILE_SEEK_INVALID_POSITION,
/**
* Packet queue is full.
*/
TOX_ERR_FILE_SEEK_SENDQ,
} Tox_Err_File_Seek;
/**
* @brief Sends a file seek control command to a friend for a given file transfer.
*
* This function can only be called to resume a file transfer right before
* TOX_FILE_CONTROL_RESUME is sent.
*
* @param friend_number The friend number of the friend the file is being
* received from.
* @param file_number The friend-specific identifier for the file transfer.
* @param position The position that the file should be seeked to.
*/
bool tox_file_seek(Tox *tox, uint32_t friend_number, uint32_t file_number, uint64_t position, Tox_Err_File_Seek *error);
typedef enum Tox_Err_File_Get {
/**
* The function returned successfully.
*/
TOX_ERR_FILE_GET_OK,
/**
* One of the arguments to the function was NULL when it was not expected.
*/
TOX_ERR_FILE_GET_NULL,
/**
* The friend_number passed did not designate a valid friend.
*/
TOX_ERR_FILE_GET_FRIEND_NOT_FOUND,
/**
* No file transfer with the given file number was found for the given friend.
*/
TOX_ERR_FILE_GET_NOT_FOUND,
} Tox_Err_File_Get;
/**
* @brief Copy the file id associated to the file transfer to a byte array.
*
* @param friend_number The friend number of the friend the file is being
* transferred to or received from.
* @param file_number The friend-specific identifier for the file transfer.
* @param file_id A memory region of at least TOX_FILE_ID_LENGTH bytes. If
* this parameter is NULL, this function has no effect.
*
* @return true on success.
*/
bool tox_file_get_file_id(const Tox *tox, uint32_t friend_number, uint32_t file_number, uint8_t *file_id,
Tox_Err_File_Get *error);
/** @} */
/** @{
* @name File transmission: sending
*/
typedef enum Tox_Err_File_Send {
/**
* The function returned successfully.
*/
TOX_ERR_FILE_SEND_OK,
/**
* One of the arguments to the function was NULL when it was not expected.
*/
TOX_ERR_FILE_SEND_NULL,
/**
* The friend_number passed did not designate a valid friend.
*/
TOX_ERR_FILE_SEND_FRIEND_NOT_FOUND,
/**
* This client is currently not connected to the friend.
*/
TOX_ERR_FILE_SEND_FRIEND_NOT_CONNECTED,
/**
* Filename length exceeded TOX_MAX_FILENAME_LENGTH bytes.
*/
TOX_ERR_FILE_SEND_NAME_TOO_LONG,
/**
* Too many ongoing transfers. The maximum number of concurrent file transfers
* is 256 per friend per direction (sending and receiving).
*/
TOX_ERR_FILE_SEND_TOO_MANY,
} Tox_Err_File_Send;
/**
* @brief Send a file transmission request.
*
* Maximum filename length is TOX_MAX_FILENAME_LENGTH bytes. The filename
* should generally just be a file name, not a path with directory names.
*
* If a non-UINT64_MAX file size is provided, it can be used by both sides to
* determine the sending progress. File size can be set to UINT64_MAX for
* streaming data of unknown size.
*
* File transmission occurs in chunks, which are requested through the
* `file_chunk_request` event.
*
* When a friend goes offline, all file transfers associated with the friend are
* purged from core.
*
* If the file contents change during a transfer, the behaviour is unspecified
* in general. What will actually happen depends on the mode in which the file
* was modified and how the client determines the file size.
*
* - If the file size was increased
* - and sending mode was streaming (file_size = UINT64_MAX), the behaviour
* will be as expected.
* - and sending mode was file (file_size != UINT64_MAX), the file_chunk_request
* callback will receive length = 0 when Core thinks the file transfer has
* finished. If the client remembers the file size as it was when sending the
* request, it will terminate the transfer normally. If the client re-reads the
* size, it will think the friend cancelled the transfer.
* - If the file size was decreased
* - and sending mode was streaming, the behaviour is as expected.
* - and sending mode was file, the callback will return 0 at the new
* (earlier) end-of-file, signalling to the friend that the transfer was
* cancelled.
* - If the file contents were modified
* - at a position before the current read, the two files (local and remote)
* will differ after the transfer terminates.
* - at a position after the current read, the file transfer will succeed as
* expected.
* - In either case, both sides will regard the transfer as complete and
* successful.
*
* @param friend_number The friend number of the friend the file send request
* should be sent to.
* @param kind The meaning of the file to be sent.
* @param file_size Size in bytes of the file the client wants to send, UINT64_MAX if
* unknown or streaming.
* @param file_id A file identifier of length TOX_FILE_ID_LENGTH that can be used to
* uniquely identify file transfers across core restarts. If NULL, a random one will
* be generated by core. It can then be obtained by using `tox_file_get_file_id()`.
* @param filename Name of the file. Does not need to be the actual name. This
* name will be sent along with the file send request.
* @param filename_length Size in bytes of the filename.
*
* @return A file number used as an identifier in subsequent callbacks. This
* number is per friend. File numbers are reused after a transfer terminates.
* On failure, this function returns an unspecified value. Any pattern in file numbers
* should not be relied on.
*/
uint32_t tox_file_send(Tox *tox, uint32_t friend_number, uint32_t kind, uint64_t file_size, const uint8_t *file_id,
const uint8_t *filename, size_t filename_length, Tox_Err_File_Send *error);
typedef enum Tox_Err_File_Send_Chunk {
/**
* The function returned successfully.
*/
TOX_ERR_FILE_SEND_CHUNK_OK,
/**
* The length parameter was non-zero, but data was NULL.
*/
TOX_ERR_FILE_SEND_CHUNK_NULL,
/**
* The friend_number passed did not designate a valid friend.
*/
TOX_ERR_FILE_SEND_CHUNK_FRIEND_NOT_FOUND,
/**
* This client is currently not connected to the friend.
*/
TOX_ERR_FILE_SEND_CHUNK_FRIEND_NOT_CONNECTED,
/**
* No file transfer with the given file number was found for the given friend.
*/
TOX_ERR_FILE_SEND_CHUNK_NOT_FOUND,
/**
* File transfer was found but isn't in a transferring state: (paused, done,
* broken, etc...) (happens only when not called from the request chunk callback).
*/
TOX_ERR_FILE_SEND_CHUNK_NOT_TRANSFERRING,
/**
* Attempted to send more or less data than requested. The requested data size is
* adjusted according to maximum transmission unit and the expected end of
* the file. Trying to send less or more than requested will return this error.
*/
TOX_ERR_FILE_SEND_CHUNK_INVALID_LENGTH,
/**
* Packet queue is full.
*/
TOX_ERR_FILE_SEND_CHUNK_SENDQ,
/**
* Position parameter was wrong.
*/
TOX_ERR_FILE_SEND_CHUNK_WRONG_POSITION,
} Tox_Err_File_Send_Chunk;
/**
* @brief Send a chunk of file data to a friend.
*
* This function is called in response to the `file_chunk_request` callback. The
* length parameter should be equal to the one received though the callback.
* If it is zero, the transfer is assumed complete. For files with known size,
* Core will know that the transfer is complete after the last byte has been
* received, so it is not necessary (though not harmful) to send a zero-length
* chunk to terminate. For streams, core will know that the transfer is finished
* if a chunk with length less than the length requested in the callback is sent.
*
* @param friend_number The friend number of the receiving friend for this file.
* @param file_number The file transfer identifier returned by tox_file_send.
* @param position The file or stream position from which to continue reading.
* @return true on success.
*/
bool tox_file_send_chunk(Tox *tox, uint32_t friend_number, uint32_t file_number, uint64_t position, const uint8_t *data,
size_t length, Tox_Err_File_Send_Chunk *error);
/**
* If the length parameter is 0, the file transfer is finished, and the client's
* resources associated with the file number should be released. After a call
* with zero length, the file number can be reused for future file transfers.
*
* If the requested position is not equal to the client's idea of the current
* file or stream position, it will need to seek. In case of read-once streams,
* the client should keep the last read chunk so that a seek back can be
* supported. A seek-back only ever needs to read from the last requested chunk.
* This happens when a chunk was requested, but the send failed. A seek-back
* request can occur an arbitrary number of times for any given chunk.
*
* In response to receiving this callback, the client should call the function
* `tox_file_send_chunk` with the requested chunk. If the number of bytes sent
* through that function is zero, the file transfer is assumed complete. A
* client must send the full length of data requested with this callback.
*
* @param friend_number The friend number of the receiving friend for this file.
* @param file_number The file transfer identifier returned by tox_file_send.
* @param position The file or stream position from which to continue reading.
* @param length The number of bytes requested for the current chunk.
*/
typedef void tox_file_chunk_request_cb(Tox *tox, uint32_t friend_number, uint32_t file_number, uint64_t position,
size_t length, void *user_data);
/**
* @brief Set the callback for the `file_chunk_request` event.
*
* Pass NULL to unset.
*
* This event is triggered when Core is ready to send more file data.
*/
void tox_callback_file_chunk_request(Tox *tox, tox_file_chunk_request_cb *callback);
/** @} */
/** @{
* @name File transmission: receiving
*/
/**
* The client should acquire resources to be associated with the file transfer.
* Incoming file transfers start in the PAUSED state. After this callback
* returns, a transfer can be rejected by sending a TOX_FILE_CONTROL_CANCEL
* control command before any other control commands. It can be accepted by
* sending TOX_FILE_CONTROL_RESUME.
*
* @param friend_number The friend number of the friend who is sending the file
* transfer request.
* @param file_number The friend-specific file number the data received is
* associated with.
* @param kind The meaning of the file that was sent.
* @param file_size Size in bytes of the file the client wants to send,
* UINT64_MAX if unknown or streaming.
* @param filename Name of the file. Does not need to be the actual name. This
* name will be sent along with the file send request.
* @param filename_length Size in bytes of the filename.
*/
typedef void tox_file_recv_cb(Tox *tox, uint32_t friend_number, uint32_t file_number, uint32_t kind, uint64_t file_size,
const uint8_t *filename, size_t filename_length, void *user_data);
/**
* @brief Set the callback for the `file_recv` event.
*
* Pass NULL to unset.
*
* This event is triggered when a file transfer request is received.
*/
void tox_callback_file_recv(Tox *tox, tox_file_recv_cb *callback);
/**
* When length is 0, the transfer is finished and the client should release the
* resources it acquired for the transfer. After a call with length = 0, the
* file number can be reused for new file transfers.
*
* If position is equal to file_size (received in the file_receive callback)
* when the transfer finishes, the file was received completely. Otherwise, if
* file_size was UINT64_MAX, streaming ended successfully when length is 0.
*
* @param friend_number The friend number of the friend who is sending the file.
* @param file_number The friend-specific file number the data received is
* associated with.
* @param position The file position of the first byte in data.
* @param data A byte array containing the received chunk.
* @param length The length of the received chunk.
*/
typedef void tox_file_recv_chunk_cb(Tox *tox, uint32_t friend_number, uint32_t file_number, uint64_t position,
const uint8_t *data, size_t length, void *user_data);
/**
* @brief Set the callback for the `file_recv_chunk` event.
*
* Pass NULL to unset.
*
* This event is first triggered when a file transfer request is received, and
* subsequently when a chunk of file data for an accepted request was received.
*/
void tox_callback_file_recv_chunk(Tox *tox, tox_file_recv_chunk_cb *callback);
/** @} */
/** @{
* @name Conference management
*/
/**
* @brief Conference types for the conference_invite event.
*/
typedef enum Tox_Conference_Type {
/**
* Text-only conferences that must be accepted with the tox_conference_join function.
*/
TOX_CONFERENCE_TYPE_TEXT,
/**
* Video conference. The function to accept these is in toxav.
*/
TOX_CONFERENCE_TYPE_AV,
} Tox_Conference_Type;
/**
* The invitation will remain valid until the inviting friend goes offline
* or exits the conference.
*
* @param friend_number The friend who invited us.
* @param type The conference type (text only or audio/video).
* @param cookie A piece of data of variable length required to join the
* conference.
* @param length The length of the cookie.
*/
typedef void tox_conference_invite_cb(Tox *tox, uint32_t friend_number, Tox_Conference_Type type, const uint8_t *cookie,
size_t length, void *user_data);
/**
* @brief Set the callback for the `conference_invite` event.
*
* Pass NULL to unset.
*
* This event is triggered when the client is invited to join a conference.
*/
void tox_callback_conference_invite(Tox *tox, tox_conference_invite_cb *callback);
/**
* @param conference_number The conference number of the conference to which we have connected.
*/
typedef void tox_conference_connected_cb(Tox *tox, uint32_t conference_number, void *user_data);
/**
* @brief Set the callback for the `conference_connected` event.
*
* Pass NULL to unset.
*
* This event is triggered when the client successfully connects to a
* conference after joining it with the tox_conference_join function.
*/
void tox_callback_conference_connected(Tox *tox, tox_conference_connected_cb *callback);
/**
* @param conference_number The conference number of the conference the message
* is intended for.
* @param peer_number The ID of the peer who sent the message.
* @param type The type of message (normal, action, ...).
* @param message The message data.
* @param length The length of the message.
*/
typedef void tox_conference_message_cb(Tox *tox, uint32_t conference_number, uint32_t peer_number,
Tox_Message_Type type, const uint8_t *message, size_t length, void *user_data);
/**
* @brief Set the callback for the `conference_message` event.
*
* Pass NULL to unset.
*
* This event is triggered when the client receives a conference message.
*/
void tox_callback_conference_message(Tox *tox, tox_conference_message_cb *callback);
/**
* @param conference_number The conference number of the conference the title
* change is intended for.
* @param peer_number The ID of the peer who changed the title.
* @param title The title data.
* @param length The title length.
*/
typedef void tox_conference_title_cb(Tox *tox, uint32_t conference_number, uint32_t peer_number, const uint8_t *title,
size_t length, void *user_data);
/**
* @brief Set the callback for the `conference_title` event.
*
* Pass NULL to unset.
*
* This event is triggered when a peer changes the conference title.
*
* If peer_number == UINT32_MAX, then author is unknown (e.g. initial joining the conference).
*/
void tox_callback_conference_title(Tox *tox, tox_conference_title_cb *callback);
/**
* @param conference_number The conference number of the conference the
* peer is in.
* @param peer_number The ID of the peer who changed their nickname.
* @param name A byte array containing the new nickname.
* @param length The size of the name byte array.
*/
typedef void tox_conference_peer_name_cb(Tox *tox, uint32_t conference_number, uint32_t peer_number,
const uint8_t *name, size_t length, void *user_data);
/**
* @brief Set the callback for the `conference_peer_name` event.
*
* Pass NULL to unset.
*
* This event is triggered when a peer changes their name.
*/
void tox_callback_conference_peer_name(Tox *tox, tox_conference_peer_name_cb *callback);
/**
* @param conference_number The conference number of the conference the
* peer is in.
*/
typedef void tox_conference_peer_list_changed_cb(Tox *tox, uint32_t conference_number, void *user_data);
/**
* @brief Set the callback for the `conference_peer_list_changed` event.
*
* Pass NULL to unset.
*
* This event is triggered when a peer joins or leaves the conference.
*/
void tox_callback_conference_peer_list_changed(Tox *tox, tox_conference_peer_list_changed_cb *callback);
typedef enum Tox_Err_Conference_New {
/**
* The function returned successfully.
*/
TOX_ERR_CONFERENCE_NEW_OK,
/**
* The conference instance failed to initialize.
*/
TOX_ERR_CONFERENCE_NEW_INIT,
} Tox_Err_Conference_New;
/**
* @brief Creates a new conference.
*
* This function creates and connects to a new text conference.
*
* @return
* - conference number on success
* - an unspecified value on failure
*/
uint32_t tox_conference_new(Tox *tox, Tox_Err_Conference_New *error);
typedef enum Tox_Err_Conference_Delete {
/**
* The function returned successfully.
*/
TOX_ERR_CONFERENCE_DELETE_OK,
/**
* The conference number passed did not designate a valid conference.
*/
TOX_ERR_CONFERENCE_DELETE_CONFERENCE_NOT_FOUND,
} Tox_Err_Conference_Delete;
/**
* @brief This function deletes a conference.
*
* @param conference_number The conference number of the conference to be deleted.
*
* @return true on success.
*/
bool tox_conference_delete(Tox *tox, uint32_t conference_number, Tox_Err_Conference_Delete *error);
/**
* @brief Error codes for peer info queries.
*/
typedef enum Tox_Err_Conference_Peer_Query {
/**
* The function returned successfully.
*/
TOX_ERR_CONFERENCE_PEER_QUERY_OK,
/**
* The conference number passed did not designate a valid conference.
*/
TOX_ERR_CONFERENCE_PEER_QUERY_CONFERENCE_NOT_FOUND,
/**
* The peer number passed did not designate a valid peer.
*/
TOX_ERR_CONFERENCE_PEER_QUERY_PEER_NOT_FOUND,
/**
* The client is not connected to the conference.
*/
TOX_ERR_CONFERENCE_PEER_QUERY_NO_CONNECTION,
} Tox_Err_Conference_Peer_Query;
/**
* @brief Return the number of online peers in the conference.
*
* The unsigned integers less than this number are the valid values of
* peer_number for the functions querying these peers. Return value is
* unspecified on failure.
*/
uint32_t tox_conference_peer_count(const Tox *tox, uint32_t conference_number, Tox_Err_Conference_Peer_Query *error);
/**
* @brief Return the length of the peer's name.
*
* Return value is unspecified on failure.
*/
size_t tox_conference_peer_get_name_size(const Tox *tox, uint32_t conference_number, uint32_t peer_number,
Tox_Err_Conference_Peer_Query *error);
/**
* @brief Copy the name of peer_number who is in conference_number to name.
*
* Call tox_conference_peer_get_name_size to determine the allocation size for the `name` parameter.
*
* @param name A valid memory region large enough to store the peer's name.
*
* @return true on success.
*/
bool tox_conference_peer_get_name(const Tox *tox, uint32_t conference_number, uint32_t peer_number, uint8_t *name,
Tox_Err_Conference_Peer_Query *error);
/**
* @brief Copy the public key of peer_number who is in conference_number to public_key.
*
* public_key must be TOX_PUBLIC_KEY_SIZE long.
*
* @return true on success.
*/
bool tox_conference_peer_get_public_key(const Tox *tox, uint32_t conference_number, uint32_t peer_number,
uint8_t *public_key, Tox_Err_Conference_Peer_Query *error);
/**
* @brief Return true if passed peer_number corresponds to our own.
*/
bool tox_conference_peer_number_is_ours(const Tox *tox, uint32_t conference_number, uint32_t peer_number,
Tox_Err_Conference_Peer_Query *error);
/**
* @brief Return the number of offline peers in the conference.
*
* The unsigned integers less than this number are the valid values of
* offline_peer_number for the functions querying these peers.
*
* Return value is unspecified on failure.
*/
uint32_t tox_conference_offline_peer_count(const Tox *tox, uint32_t conference_number,
Tox_Err_Conference_Peer_Query *error);
/**
* @brief Return the length of the offline peer's name.
*
* Return value is unspecified on failure.
*/
size_t tox_conference_offline_peer_get_name_size(const Tox *tox, uint32_t conference_number,
uint32_t offline_peer_number, Tox_Err_Conference_Peer_Query *error);
/**
* @brief Copy the name of offline_peer_number who is in conference_number to name.
*
* Call tox_conference_offline_peer_get_name_size to determine the allocation
* size for the `name` parameter.
*
* @param name A valid memory region large enough to store the peer's name.
*
* @return true on success.
*/
bool tox_conference_offline_peer_get_name(const Tox *tox, uint32_t conference_number, uint32_t offline_peer_number,
uint8_t *name, Tox_Err_Conference_Peer_Query *error);
/**
* @brief Copy the public key of offline_peer_number who is in conference_number to public_key.
*
* public_key must be TOX_PUBLIC_KEY_SIZE long.
*
* @return true on success.
*/
bool tox_conference_offline_peer_get_public_key(const Tox *tox, uint32_t conference_number,
uint32_t offline_peer_number, uint8_t *public_key, Tox_Err_Conference_Peer_Query *error);
/**
* @brief Return a unix-time timestamp of the last time offline_peer_number was seen to be active.
*/
uint64_t tox_conference_offline_peer_get_last_active(const Tox *tox, uint32_t conference_number,
uint32_t offline_peer_number, Tox_Err_Conference_Peer_Query *error);
typedef enum Tox_Err_Conference_Set_Max_Offline {
/**
* The function returned successfully.
*/
TOX_ERR_CONFERENCE_SET_MAX_OFFLINE_OK,
/**
* The conference number passed did not designate a valid conference.
*/
TOX_ERR_CONFERENCE_SET_MAX_OFFLINE_CONFERENCE_NOT_FOUND,
} Tox_Err_Conference_Set_Max_Offline;
/**
* @brief Set maximum number of offline peers to store, overriding the default.
*/
bool tox_conference_set_max_offline(Tox *tox, uint32_t conference_number, uint32_t max_offline_peers,
Tox_Err_Conference_Set_Max_Offline *error);
typedef enum Tox_Err_Conference_Invite {
/**
* The function returned successfully.
*/
TOX_ERR_CONFERENCE_INVITE_OK,
/**
* The conference number passed did not designate a valid conference.
*/
TOX_ERR_CONFERENCE_INVITE_CONFERENCE_NOT_FOUND,
/**
* The invite packet failed to send.
*/
TOX_ERR_CONFERENCE_INVITE_FAIL_SEND,
/**
* The client is not connected to the conference.
*/
TOX_ERR_CONFERENCE_INVITE_NO_CONNECTION,
} Tox_Err_Conference_Invite;
/**
* @brief Invites a friend to a conference.
*
* @param friend_number The friend number of the friend we want to invite.
* @param conference_number The conference number of the conference we want to invite the friend to.
*
* @return true on success.
*/
bool tox_conference_invite(Tox *tox, uint32_t friend_number, uint32_t conference_number,
Tox_Err_Conference_Invite *error);
typedef enum Tox_Err_Conference_Join {
/**
* The function returned successfully.
*/
TOX_ERR_CONFERENCE_JOIN_OK,
/**
* The cookie passed has an invalid length.
*/
TOX_ERR_CONFERENCE_JOIN_INVALID_LENGTH,
/**
* The conference is not the expected type. This indicates an invalid cookie.
*/
TOX_ERR_CONFERENCE_JOIN_WRONG_TYPE,
/**
* The friend number passed does not designate a valid friend.
*/
TOX_ERR_CONFERENCE_JOIN_FRIEND_NOT_FOUND,
/**
* Client is already in this conference.
*/
TOX_ERR_CONFERENCE_JOIN_DUPLICATE,
/**
* Conference instance failed to initialize.
*/
TOX_ERR_CONFERENCE_JOIN_INIT_FAIL,
/**
* The join packet failed to send.
*/
TOX_ERR_CONFERENCE_JOIN_FAIL_SEND,
} Tox_Err_Conference_Join;
/**
* @brief Joins a conference that the client has been invited to.
*
* After successfully joining the conference, the client will not be "connected"
* to it until a handshaking procedure has been completed. A
* `conference_connected` event will then occur for the conference. The client
* will then remain connected to the conference until the conference is deleted,
* even across core restarts. Many operations on a conference will fail with a
* corresponding error if attempted on a conference to which the client is not
* yet connected.
*
* @param friend_number The friend number of the friend who sent the invite.
* @param cookie Received via the `conference_invite` event.
* @param length The size of cookie.
*
* @return conference number on success, an unspecified value on failure.
*/
uint32_t tox_conference_join(Tox *tox, uint32_t friend_number, const uint8_t *cookie, size_t length,
Tox_Err_Conference_Join *error);
typedef enum Tox_Err_Conference_Send_Message {
/**
* The function returned successfully.
*/
TOX_ERR_CONFERENCE_SEND_MESSAGE_OK,
/**
* The conference number passed did not designate a valid conference.
*/
TOX_ERR_CONFERENCE_SEND_MESSAGE_CONFERENCE_NOT_FOUND,
/**
* The message is too long.
*/
TOX_ERR_CONFERENCE_SEND_MESSAGE_TOO_LONG,
/**
* The client is not connected to the conference.
*/
TOX_ERR_CONFERENCE_SEND_MESSAGE_NO_CONNECTION,
/**
* The message packet failed to send.
*/
TOX_ERR_CONFERENCE_SEND_MESSAGE_FAIL_SEND,
} Tox_Err_Conference_Send_Message;
/**
* @brief Send a text chat message to the conference.
*
* This function creates a conference message packet and pushes it into the send
* queue.
*
* The message length may not exceed TOX_MAX_MESSAGE_LENGTH. Larger messages
* must be split by the client and sent as separate messages. Other clients can
* then reassemble the fragments.
*
* @param conference_number The conference number of the conference the message
* is intended for.
* @param type Message type (normal, action, ...).
* @param message A non-NULL pointer to the first element of a byte array
* containing the message text.
* @param length Length of the message to be sent.
*
* @return true on success.
*/
bool tox_conference_send_message(Tox *tox, uint32_t conference_number, Tox_Message_Type type, const uint8_t *message,
size_t length, Tox_Err_Conference_Send_Message *error);
typedef enum Tox_Err_Conference_Title {
/**
* The function returned successfully.
*/
TOX_ERR_CONFERENCE_TITLE_OK,
/**
* The conference number passed did not designate a valid conference.
*/
TOX_ERR_CONFERENCE_TITLE_CONFERENCE_NOT_FOUND,
/**
* The title is too long or empty.
*/
TOX_ERR_CONFERENCE_TITLE_INVALID_LENGTH,
/**
* The title packet failed to send.
*/
TOX_ERR_CONFERENCE_TITLE_FAIL_SEND,
} Tox_Err_Conference_Title;
/**
* @brief Return the length of the conference title.
*
* Return value is unspecified on failure.
*
* The return value is equal to the `length` argument received by the last
* `conference_title` callback.
*/
size_t tox_conference_get_title_size(const Tox *tox, uint32_t conference_number, Tox_Err_Conference_Title *error);
/**
* @brief Write the title designated by the given conference number to a byte array.
*
* Call tox_conference_get_title_size to determine the allocation size for the `title` parameter.
*
* The data written to `title` is equal to the data received by the last
* `conference_title` callback.
*
* @param title A valid memory region large enough to store the title.
* If this parameter is NULL, this function has no effect.
*
* @return true on success.
*/
bool tox_conference_get_title(const Tox *tox, uint32_t conference_number, uint8_t *title,
Tox_Err_Conference_Title *error);
/**
* @brief Set the conference title and broadcast it to the rest of the conference.
*
* Title length cannot be longer than TOX_MAX_NAME_LENGTH.
*
* @return true on success.
*/
bool tox_conference_set_title(Tox *tox, uint32_t conference_number, const uint8_t *title, size_t length,
Tox_Err_Conference_Title *error);
/**
* @brief Return the number of conferences in the Tox instance.
*
* This should be used to determine how much memory to allocate for `tox_conference_get_chatlist`.
*/
size_t tox_conference_get_chatlist_size(const Tox *tox);
/**
* @brief Copy a list of valid conference numbers into the array chatlist.
*
* Determine how much space to allocate for the array with the
* `tox_conference_get_chatlist_size` function.
*
* Note that `tox_get_savedata` saves all connected conferences;
* when toxcore is created from savedata in which conferences were saved, those
* conferences will be connected at startup, and will be listed by
* `tox_conference_get_chatlist`.
*
* The conference number of a loaded conference may differ from the conference
* number it had when it was saved.
*/
void tox_conference_get_chatlist(const Tox *tox, uint32_t *chatlist);
/**
* @brief Returns the type of conference (Tox_Conference_Type) that conference_number is.
*
* Return value is unspecified on failure.
*/
typedef enum Tox_Err_Conference_Get_Type {
/**
* The function returned successfully.
*/
TOX_ERR_CONFERENCE_GET_TYPE_OK,
/**
* The conference number passed did not designate a valid conference.
*/
TOX_ERR_CONFERENCE_GET_TYPE_CONFERENCE_NOT_FOUND,
} Tox_Err_Conference_Get_Type;
/**
* @brief Get the type (text or A/V) for the conference.
*/
Tox_Conference_Type tox_conference_get_type(const Tox *tox, uint32_t conference_number,
Tox_Err_Conference_Get_Type *error);
/**
* @brief Get the conference unique ID.
*
* If id is NULL, this function has no effect.
*
* @param id A memory region large enough to store TOX_CONFERENCE_ID_SIZE bytes.
*
* @return true on success.
*/
bool tox_conference_get_id(const Tox *tox, uint32_t conference_number, uint8_t *id);
typedef enum Tox_Err_Conference_By_Id {
/**
* The function returned successfully.
*/
TOX_ERR_CONFERENCE_BY_ID_OK,
/**
* One of the arguments to the function was NULL when it was not expected.
*/
TOX_ERR_CONFERENCE_BY_ID_NULL,
/**
* No conference with the given id exists on the conference list.
*/
TOX_ERR_CONFERENCE_BY_ID_NOT_FOUND,
} Tox_Err_Conference_By_Id;
/**
* @brief Return the conference number associated with the specified id.
*
* @param id A byte array containing the conference id (TOX_CONFERENCE_ID_SIZE).
*
* @return the conference number on success, an unspecified value on failure.
*/
uint32_t tox_conference_by_id(const Tox *tox, const uint8_t *id, Tox_Err_Conference_By_Id *error);
/**
* @brief Get the conference unique ID.
*
* If uid is NULL, this function has no effect.
*
* @param uid A memory region large enough to store TOX_CONFERENCE_UID_SIZE bytes.
*
* @return true on success.
* @deprecated use tox_conference_get_id instead (exactly the same function, just renamed).
*/
bool tox_conference_get_uid(const Tox *tox, uint32_t conference_number, uint8_t *uid);
typedef enum Tox_Err_Conference_By_Uid {
/**
* The function returned successfully.
*/
TOX_ERR_CONFERENCE_BY_UID_OK,
/**
* One of the arguments to the function was NULL when it was not expected.
*/
TOX_ERR_CONFERENCE_BY_UID_NULL,
/**
* No conference with the given uid exists on the conference list.
*/
TOX_ERR_CONFERENCE_BY_UID_NOT_FOUND,
} Tox_Err_Conference_By_Uid;
/**
* @brief Return the conference number associated with the specified uid.
*
* @param uid A byte array containing the conference id (TOX_CONFERENCE_UID_SIZE).
*
* @return the conference number on success, an unspecified value on failure.
* @deprecated use tox_conference_by_id instead (exactly the same function, just renamed).
*/
uint32_t tox_conference_by_uid(const Tox *tox, const uint8_t *uid, Tox_Err_Conference_By_Uid *error);
/** @} */
/** @{
* @name Low-level custom packet sending and receiving
*/
typedef enum Tox_Err_Friend_Custom_Packet {
/**
* The function returned successfully.
*/
TOX_ERR_FRIEND_CUSTOM_PACKET_OK,
/**
* One of the arguments to the function was NULL when it was not expected.
*/
TOX_ERR_FRIEND_CUSTOM_PACKET_NULL,
/**
* The friend number did not designate a valid friend.
*/
TOX_ERR_FRIEND_CUSTOM_PACKET_FRIEND_NOT_FOUND,
/**
* This client is currently not connected to the friend.
*/
TOX_ERR_FRIEND_CUSTOM_PACKET_FRIEND_NOT_CONNECTED,
/**
* The first byte of data was not in the specified range for the packet type.
* This range is 192-254 for lossy, and 69, 160-191 for lossless packets.
*/
TOX_ERR_FRIEND_CUSTOM_PACKET_INVALID,
/**
* Attempted to send an empty packet.
*/
TOX_ERR_FRIEND_CUSTOM_PACKET_EMPTY,
/**
* Packet data length exceeded TOX_MAX_CUSTOM_PACKET_SIZE.
*/
TOX_ERR_FRIEND_CUSTOM_PACKET_TOO_LONG,
/**
* Packet queue is full.
*/
TOX_ERR_FRIEND_CUSTOM_PACKET_SENDQ,
} Tox_Err_Friend_Custom_Packet;
/**
* @brief Send a custom lossy packet to a friend.
*
* The first byte of data must be in the range 192-254. Maximum length of a
* custom packet is TOX_MAX_CUSTOM_PACKET_SIZE.
*
* Lossy packets behave like UDP packets, meaning they might never reach the
* other side or might arrive more than once (if someone is messing with the
* connection) or might arrive in the wrong order.
*
* Unless latency is an issue, it is recommended that you use lossless custom
* packets instead.
*
* @param friend_number The friend number of the friend this lossy packet
* should be sent to.
* @param data A byte array containing the packet data.
* @param length The length of the packet data byte array.
*
* @return true on success.
*/
bool tox_friend_send_lossy_packet(Tox *tox, uint32_t friend_number, const uint8_t *data, size_t length,
Tox_Err_Friend_Custom_Packet *error);
/**
* @brief Send a custom lossless packet to a friend.
*
* The first byte of data must be in the range 69, 160-191. Maximum length of a
* custom packet is TOX_MAX_CUSTOM_PACKET_SIZE.
*
* Lossless packet behaviour is comparable to TCP (reliability, arrive in order)
* but with packets instead of a stream.
*
* @param friend_number The friend number of the friend this lossless packet
* should be sent to.
* @param data A byte array containing the packet data.
* @param length The length of the packet data byte array.
*
* @return true on success.
*/
bool tox_friend_send_lossless_packet(Tox *tox, uint32_t friend_number, const uint8_t *data, size_t length,
Tox_Err_Friend_Custom_Packet *error);
/**
* @param friend_number The friend number of the friend who sent a lossy packet.
* @param data A byte array containing the received packet data.
* @param length The length of the packet data byte array.
*/
typedef void tox_friend_lossy_packet_cb(Tox *tox, uint32_t friend_number, const uint8_t *data, size_t length,
void *user_data);
/**
* @brief Set the callback for the `friend_lossy_packet` event.
*
* Pass NULL to unset.
*/
void tox_callback_friend_lossy_packet(Tox *tox, tox_friend_lossy_packet_cb *callback);
/**
* @param friend_number The friend number of the friend who sent the packet.
* @param data A byte array containing the received packet data.
* @param length The length of the packet data byte array.
*/
typedef void tox_friend_lossless_packet_cb(Tox *tox, uint32_t friend_number, const uint8_t *data, size_t length,
void *user_data);
/**
* @brief Set the callback for the `friend_lossless_packet` event.
*
* Pass NULL to unset.
*/
void tox_callback_friend_lossless_packet(Tox *tox, tox_friend_lossless_packet_cb *callback);
/** @} */
/** @{
* @name Low-level network information
*/
typedef enum Tox_Err_Get_Port {
/**
* The function returned successfully.
*/
TOX_ERR_GET_PORT_OK,
/**
* The instance was not bound to any port.
*/
TOX_ERR_GET_PORT_NOT_BOUND,
} Tox_Err_Get_Port;
/**
* @brief Writes the temporary DHT public key of this instance to a byte array.
*
* This can be used in combination with an externally accessible IP address and
* the bound port (from tox_self_get_udp_port) to run a temporary bootstrap node.
*
* Be aware that every time a new instance is created, the DHT public key
* changes, meaning this cannot be used to run a permanent bootstrap node.
*
* @param dht_id A memory region of at least TOX_PUBLIC_KEY_SIZE bytes. If this
* parameter is NULL, this function has no effect.
*/
void tox_self_get_dht_id(const Tox *tox, uint8_t *dht_id);
/**
* @brief Return the UDP port this Tox instance is bound to.
*/
uint16_t tox_self_get_udp_port(const Tox *tox, Tox_Err_Get_Port *error);
/**
* @brief Return the TCP port this Tox instance is bound to.
*
* This is only relevant if the instance is acting as a TCP relay.
*/
uint16_t tox_self_get_tcp_port(const Tox *tox, Tox_Err_Get_Port *error);
/** @} */
/*******************************************************************************
*
* :: Group chats
*
******************************************************************************/
/*******************************************************************************
*
* :: Group chat numeric constants
*
******************************************************************************/
/** @{
* Maximum length of a group topic.
*/
#define TOX_GROUP_MAX_TOPIC_LENGTH 512
uint32_t tox_group_max_topic_length(void);
/**
* Maximum length of a peer part message.
*/
#define TOX_GROUP_MAX_PART_LENGTH 128
uint32_t tox_group_max_part_length(void);
/**
* Maximum length of a group text message.
*/
#define TOX_GROUP_MAX_MESSAGE_LENGTH 1372
uint32_t tox_group_max_message_length(void);
/**
* Maximum length of a group custom lossy packet.
*/
#define TOX_GROUP_MAX_CUSTOM_LOSSY_PACKET_LENGTH 500
uint32_t tox_group_max_custom_lossy_packet_length(void);
/**
* Maximum length of a group custom lossless packet.
*/
#define TOX_GROUP_MAX_CUSTOM_LOSSLESS_PACKET_LENGTH 1373
uint32_t tox_group_max_custom_lossless_packet_length(void);
/**
* Maximum length of a group name.
*/
#define TOX_GROUP_MAX_GROUP_NAME_LENGTH 48
uint32_t tox_group_max_group_name_length(void);
/**
* Maximum length of a group password.
*/
#define TOX_GROUP_MAX_PASSWORD_SIZE 32
uint32_t tox_group_max_password_size(void);
/**
* Number of bytes in a group Chat ID.
*/
#define TOX_GROUP_CHAT_ID_SIZE 32
uint32_t tox_group_chat_id_size(void);
/**
* Size of a peer public key.
*/
#define TOX_GROUP_PEER_PUBLIC_KEY_SIZE 32
uint32_t tox_group_peer_public_key_size(void);
/*******************************************************************************
*
* :: Group chat state enumerators
*
******************************************************************************/
/**
* Represents the group privacy state.
*/
typedef enum Tox_Group_Privacy_State {
/**
* The group is considered to be public. Anyone may join the group using the Chat ID.
*
* If the group is in this state, even if the Chat ID is never explicitly shared
* with someone outside of the group, information including the Chat ID, IP addresses,
* and peer ID's (but not Tox ID's) is visible to anyone with access to a node
* storing a DHT entry for the given group.
*/
TOX_GROUP_PRIVACY_STATE_PUBLIC,
/**
* The group is considered to be private. The only way to join the group is by having
* someone in your contact list send you an invite.
*
* If the group is in this state, no group information (mentioned above) is present in the DHT;
* the DHT is not used for any purpose at all. If a public group is set to private,
* all DHT information related to the group will expire shortly.
*/
TOX_GROUP_PRIVACY_STATE_PRIVATE,
} Tox_Group_Privacy_State;
/**
* Represents the state of the group topic lock.
*/
typedef enum Tox_Group_Topic_Lock {
/**
* The topic lock is enabled. Only peers with the founder and moderator roles may set the topic.
*/
TOX_GROUP_TOPIC_LOCK_ENABLED,
/**
* The topic lock is disabled. All peers except those with the observer role may set the topic.
*/
TOX_GROUP_TOPIC_LOCK_DISABLED,
} Tox_Group_Topic_Lock;
/**
* Represents the group voice state, which determines which Group Roles have permission to speak
* in the group chat. The voice state does not have any effect private messages or topic setting.
*/
typedef enum Tox_Group_Voice_State {
/**
* All group roles above Observer have permission to speak.
*/
TOX_GROUP_VOICE_STATE_ALL,
/**
* Moderators and Founders have permission to speak.
*/
TOX_GROUP_VOICE_STATE_MODERATOR,
/**
* Only the founder may speak.
*/
TOX_GROUP_VOICE_STATE_FOUNDER,
} Tox_Group_Voice_State;
/**
* Represents group roles.
*
* Roles are hierarchical in that each role has a set of privileges plus all the privileges
* of the roles below it.
*/
typedef enum Tox_Group_Role {
/**
* May kick all other peers as well as set their role to anything (except founder).
* Founders may also set the group password, toggle the privacy state, and set the peer limit.
*/
TOX_GROUP_ROLE_FOUNDER,
/**
* May kick and set the user and observer roles for peers below this role.
* May also set the group topic.
*/
TOX_GROUP_ROLE_MODERATOR,
/**
* May communicate with other peers normally.
*/
TOX_GROUP_ROLE_USER,
/**
* May observe the group and ignore peers; may not communicate with other peers or with the group.
*/
TOX_GROUP_ROLE_OBSERVER,
} Tox_Group_Role;
/*******************************************************************************
*
* :: Group chat instance management
*
******************************************************************************/
typedef enum Tox_Err_Group_New {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_NEW_OK,
/**
* name exceeds TOX_MAX_NAME_LENGTH or group_name exceeded TOX_GROUP_MAX_GROUP_NAME_LENGTH.
*/
TOX_ERR_GROUP_NEW_TOO_LONG,
/**
* name or group_name is NULL or length is zero.
*/
TOX_ERR_GROUP_NEW_EMPTY,
/**
* The group instance failed to initialize.
*/
TOX_ERR_GROUP_NEW_INIT,
/**
* The group state failed to initialize. This usually indicates that something went wrong
* related to cryptographic signing.
*/
TOX_ERR_GROUP_NEW_STATE,
/**
* The group failed to announce to the DHT. This indicates a network related error.
*/
TOX_ERR_GROUP_NEW_ANNOUNCE,
} Tox_Err_Group_New;
/**
* Creates a new group chat.
*
* This function creates a new group chat object and adds it to the chats array.
*
* The caller of this function has Founder role privileges.
*
* The client should initiate its peer list with self info after calling this function, as
* the peer_join callback will not be triggered.
*
* @param privacy_state The privacy state of the group. If this is set to TOX_GROUP_PRIVACY_STATE_PUBLIC,
* the group will attempt to announce itself to the DHT and anyone with the Chat ID may join.
* Otherwise a friend invite will be required to join the group.
* @param group_name The name of the group. The name must be non-NULL.
* @param group_name_length The length of the group name. This must be greater than zero and no larger than
* TOX_GROUP_MAX_GROUP_NAME_LENGTH.
* @param name The name of the peer creating the group.
* @param name_length The length of the peer's name. This must be greater than zero and no larger
* than TOX_MAX_NAME_LENGTH.
*
* @return group_number on success, UINT32_MAX on failure.
*/
uint32_t tox_group_new(Tox *tox, Tox_Group_Privacy_State privacy_state, const uint8_t *group_name,
size_t group_name_length, const uint8_t *name, size_t name_length, Tox_Err_Group_New *error);
typedef enum Tox_Err_Group_Join {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_JOIN_OK,
/**
* The group instance failed to initialize.
*/
TOX_ERR_GROUP_JOIN_INIT,
/**
* The chat_id pointer is set to NULL or a group with chat_id already exists. This usually
* happens if the client attempts to create multiple sessions for the same group.
*/
TOX_ERR_GROUP_JOIN_BAD_CHAT_ID,
/**
* name is NULL or name_length is zero.
*/
TOX_ERR_GROUP_JOIN_EMPTY,
/**
* name exceeds TOX_MAX_NAME_LENGTH.
*/
TOX_ERR_GROUP_JOIN_TOO_LONG,
/**
* Failed to set password. This usually occurs if the password exceeds TOX_GROUP_MAX_PASSWORD_SIZE.
*/
TOX_ERR_GROUP_JOIN_PASSWORD,
/**
* There was a core error when initiating the group.
*/
TOX_ERR_GROUP_JOIN_CORE,
} Tox_Err_Group_Join;
/**
* Joins a group chat with specified Chat ID.
*
* This function creates a new group chat object, adds it to the chats array, and sends
* a DHT announcement to find peers in the group associated with chat_id. Once a peer has been
* found a join attempt will be initiated.
*
* @param chat_id The Chat ID of the group you wish to join. This must be TOX_GROUP_CHAT_ID_SIZE bytes.
* @param password The password required to join the group. Set to NULL if no password is required.
* @param password_length The length of the password. If length is equal to zero,
* the password parameter is ignored. length must be no larger than TOX_GROUP_MAX_PASSWORD_SIZE.
* @param name The name of the peer joining the group.
* @param name_length The length of the peer's name. This must be greater than zero and no larger
* than TOX_MAX_NAME_LENGTH.
*
* @return group_number on success, UINT32_MAX on failure.
*/
uint32_t tox_group_join(Tox *tox, const uint8_t *chat_id, const uint8_t *name, size_t name_length,
const uint8_t *password, size_t password_length, Tox_Err_Group_Join *error);
typedef enum Tox_Err_Group_Is_Connected {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_IS_CONNECTED_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_IS_CONNECTED_GROUP_NOT_FOUND,
} Tox_Err_Group_Is_Connected;
/**
* Returns true if the group chat is currently connected or attempting to connect to other peers
* in the group.
*
* @param group_number The group number of the designated group.
*/
bool tox_group_is_connected(const Tox *tox, uint32_t group_number, Tox_Err_Group_Is_Connected *error);
typedef enum Tox_Err_Group_Disconnect {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_DISCONNECT_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_DISCONNECT_GROUP_NOT_FOUND,
/**
* The group is already disconnected.
*/
TOX_ERR_GROUP_DISCONNECT_ALREADY_DISCONNECTED,
} Tox_Err_Group_Disconnect;
/**
* Disconnects from a group chat while retaining the group state and credentials.
*
* Returns true if we successfully disconnect from the group.
*
* @param group_number The group number of the designated group.
*/
bool tox_group_disconnect(const Tox *tox, uint32_t group_number, Tox_Err_Group_Disconnect *error);
typedef enum Tox_Err_Group_Reconnect {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_RECONNECT_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_RECONNECT_GROUP_NOT_FOUND,
/**
* There was a core error when initiating the group.
*/
TOX_ERR_GROUP_RECONNECT_CORE,
} Tox_Err_Group_Reconnect;
/**
* Reconnects to a group.
*
* This function disconnects from all peers in the group, then attempts to reconnect with the group.
* The caller's state is not changed (i.e. name, status, role, chat public key etc.).
*
* @param group_number The group number of the group we wish to reconnect to.
*
* @return true on success.
*/
bool tox_group_reconnect(Tox *tox, uint32_t group_number, Tox_Err_Group_Reconnect *error);
typedef enum Tox_Err_Group_Leave {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_LEAVE_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_LEAVE_GROUP_NOT_FOUND,
/**
* Message length exceeded TOX_GROUP_MAX_PART_LENGTH.
*/
TOX_ERR_GROUP_LEAVE_TOO_LONG,
/**
* The parting packet failed to send.
*/
TOX_ERR_GROUP_LEAVE_FAIL_SEND,
} Tox_Err_Group_Leave;
/**
* Leaves a group.
*
* This function sends a parting packet containing a custom (non-obligatory) message to all
* peers in a group, and deletes the group from the chat array. All group state information is permanently
* lost, including keys and role credentials.
*
* @param group_number The group number of the group we wish to leave.
* @param part_message The parting message to be sent to all the peers. Set to NULL if we do not wish to
* send a parting message.
* @param length The length of the parting message. Set to 0 if we do not wish to send a parting message.
*
* @return true if the group chat instance is successfully deleted.
*/
bool tox_group_leave(Tox *tox, uint32_t group_number, const uint8_t *part_message, size_t length,
Tox_Err_Group_Leave *error);
/*******************************************************************************
*
* :: Group user-visible client information (nickname/status/role/public key)
*
******************************************************************************/
/**
* General error codes for self state get and size functions.
*/
typedef enum Tox_Err_Group_Self_Query {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_SELF_QUERY_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_SELF_QUERY_GROUP_NOT_FOUND,
} Tox_Err_Group_Self_Query;
/**
* Error codes for self name setting.
*/
typedef enum Tox_Err_Group_Self_Name_Set {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_SELF_NAME_SET_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_SELF_NAME_SET_GROUP_NOT_FOUND,
/**
* Name length exceeded TOX_MAX_NAME_LENGTH.
*/
TOX_ERR_GROUP_SELF_NAME_SET_TOO_LONG,
/**
* The length given to the set function is zero or name is a NULL pointer.
*/
TOX_ERR_GROUP_SELF_NAME_SET_INVALID,
/**
* The packet failed to send.
*/
TOX_ERR_GROUP_SELF_NAME_SET_FAIL_SEND,
} Tox_Err_Group_Self_Name_Set;
/**
* Set the client's nickname for the group instance designated by the given group number.
*
* Nickname length cannot exceed TOX_MAX_NAME_LENGTH. If length is equal to zero or name is a NULL
* pointer, the function call will fail.
*
* @param name A byte array containing the new nickname.
* @param length The size of the name byte array.
*
* @return true on success.
*/
bool tox_group_self_set_name(const Tox *tox, uint32_t group_number, const uint8_t *name, size_t length,
Tox_Err_Group_Self_Name_Set *error);
/**
* Return the length of the client's current nickname for the group instance designated
* by group_number as passed to tox_group_self_set_name.
*
* If no nickname was set before calling this function, the name is empty,
* and this function returns 0.
*
* @see threading for concurrency implications.
*/
size_t tox_group_self_get_name_size(const Tox *tox, uint32_t group_number, Tox_Err_Group_Self_Query *error);
/**
* Write the nickname set by tox_group_self_set_name to a byte array.
*
* If no nickname was set before calling this function, the name is empty,
* and this function has no effect.
*
* Call tox_group_self_get_name_size to find out how much memory to allocate for the result.
*
* @param name A valid memory location large enough to hold the nickname.
* If this parameter is NULL, the function has no effect.
*
* @return true on success.
*/
bool tox_group_self_get_name(const Tox *tox, uint32_t group_number, uint8_t *name, Tox_Err_Group_Self_Query *error);
/**
* Error codes for self status setting.
*/
typedef enum Tox_Err_Group_Self_Status_Set {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_SELF_STATUS_SET_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_SELF_STATUS_SET_GROUP_NOT_FOUND,
/**
* The packet failed to send.
*/
TOX_ERR_GROUP_SELF_STATUS_SET_FAIL_SEND,
} Tox_Err_Group_Self_Status_Set;
/**
* Set the client's status for the group instance. Status must be a Tox_User_Status.
*
* @return true on success.
*/
bool tox_group_self_set_status(const Tox *tox, uint32_t group_number, Tox_User_Status status,
Tox_Err_Group_Self_Status_Set *error);
/**
* returns the client's status for the group instance on success.
* return value is unspecified on failure.
*/
Tox_User_Status tox_group_self_get_status(const Tox *tox, uint32_t group_number, Tox_Err_Group_Self_Query *error);
/**
* returns the client's role for the group instance on success.
* return value is unspecified on failure.
*/
Tox_Group_Role tox_group_self_get_role(const Tox *tox, uint32_t group_number, Tox_Err_Group_Self_Query *error);
/**
* returns the client's peer id for the group instance on success.
* return value is unspecified on failure.
*/
uint32_t tox_group_self_get_peer_id(const Tox *tox, uint32_t group_number, Tox_Err_Group_Self_Query *error);
/**
* Write the client's group public key designated by the given group number to a byte array.
*
* This key will be permanently tied to the client's identity for this particular group until
* the client explicitly leaves the group. This key is the only way for other peers to reliably
* identify the client across client restarts.
*
* `public_key` should have room for at least TOX_GROUP_PEER_PUBLIC_KEY_SIZE bytes.
*
* @param public_key A valid memory region large enough to store the public key.
* If this parameter is NULL, this function call has no effect.
*
* @return true on success.
*/
bool tox_group_self_get_public_key(const Tox *tox, uint32_t group_number, uint8_t *public_key,
Tox_Err_Group_Self_Query *error);
/*******************************************************************************
*
* :: Peer-specific group state queries.
*
******************************************************************************/
/**
* Error codes for peer info queries.
*/
typedef enum Tox_Err_Group_Peer_Query {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_PEER_QUERY_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_PEER_QUERY_GROUP_NOT_FOUND,
/**
* The ID passed did not designate a valid peer.
*/
TOX_ERR_GROUP_PEER_QUERY_PEER_NOT_FOUND,
} Tox_Err_Group_Peer_Query;
/**
* Return the length of the peer's name. If the group number or ID is invalid, the
* return value is unspecified.
*
* @param group_number The group number of the group we wish to query.
* @param peer_id The ID of the peer whose name length we want to retrieve.
*
* The return value is equal to the `length` argument received by the last
* `group_peer_name` callback.
*/
size_t tox_group_peer_get_name_size(const Tox *tox, uint32_t group_number, uint32_t peer_id,
Tox_Err_Group_Peer_Query *error);
/**
* Write the name of the peer designated by the given ID to a byte
* array.
*
* Call tox_group_peer_get_name_size to determine the allocation size for the `name` parameter.
*
* The data written to `name` is equal to the data received by the last
* `group_peer_name` callback.
*
* @param group_number The group number of the group we wish to query.
* @param peer_id The ID of the peer whose name we wish to retrieve.
* @param name A valid memory region large enough to store the friend's name.
*
* @return true on success.
*/
bool tox_group_peer_get_name(const Tox *tox, uint32_t group_number, uint32_t peer_id, uint8_t *name,
Tox_Err_Group_Peer_Query *error);
/**
* Return the peer's user status (away/busy/...). If the ID or group number is
* invalid, the return value is unspecified.
*
* @param group_number The group number of the group we wish to query.
* @param peer_id The ID of the peer whose status we wish to query.
*
* The status returned is equal to the last status received through the
* `group_peer_status` callback.
*/
Tox_User_Status tox_group_peer_get_status(const Tox *tox, uint32_t group_number, uint32_t peer_id,
Tox_Err_Group_Peer_Query *error);
/**
* Return the peer's role (user/moderator/founder...). If the ID or group number is
* invalid, the return value is unspecified.
*
* @param group_number The group number of the group we wish to query.
* @param peer_id The ID of the peer whose role we wish to query.
*
* The role returned is equal to the last role received through the
* `group_moderation` callback.
*/
Tox_Group_Role tox_group_peer_get_role(const Tox *tox, uint32_t group_number, uint32_t peer_id,
Tox_Err_Group_Peer_Query *error);
/**
* Return the type of connection we have established with a peer.
*
* This function will return an error if called on ourselves.
*
* @param group_number The group number of the group we wish to query.
* @param peer_id The ID of the peer whose connection status we wish to query.
*/
Tox_Connection tox_group_peer_get_connection_status(const Tox *tox, uint32_t group_number, uint32_t peer_id,
Tox_Err_Group_Peer_Query *error);
/**
* Write the group public key with the designated peer_id for the designated group number to public_key.
*
* This key will be permanently tied to a particular peer until they explicitly leave the group and is
* the only way to reliably identify the same peer across client restarts.
*
* `public_key` should have room for at least TOX_GROUP_PEER_PUBLIC_KEY_SIZE bytes. If `public_key` is null
* this function has no effect.
*
* @param group_number The group number of the group we wish to query.
* @param peer_id The ID of the peer whose public key we wish to retrieve.
* @param public_key A valid memory region large enough to store the public key.
* If this parameter is NULL, this function call has no effect.
*
* @return true on success.
*/
bool tox_group_peer_get_public_key(const Tox *tox, uint32_t group_number, uint32_t peer_id, uint8_t *public_key,
Tox_Err_Group_Peer_Query *error);
/**
* @param group_number The group number of the group the name change is intended for.
* @param peer_id The ID of the peer who has changed their name.
* @param name The name data.
* @param length The length of the name.
*/
typedef void tox_group_peer_name_cb(Tox *tox, uint32_t group_number, uint32_t peer_id, const uint8_t *name,
size_t length, void *user_data);
/**
* Set the callback for the `group_peer_name` event. Pass NULL to unset.
*
* This event is triggered when a peer changes their nickname.
*/
void tox_callback_group_peer_name(Tox *tox, tox_group_peer_name_cb *callback);
/**
* @param group_number The group number of the group the status change is intended for.
* @param peer_id The ID of the peer who has changed their status.
* @param status The new status of the peer.
*/
typedef void tox_group_peer_status_cb(Tox *tox, uint32_t group_number, uint32_t peer_id, Tox_User_Status status,
void *user_data);
/**
* Set the callback for the `group_peer_status` event. Pass NULL to unset.
*
* This event is triggered when a peer changes their status.
*/
void tox_callback_group_peer_status(Tox *tox, tox_group_peer_status_cb *callback);
/*******************************************************************************
*
* :: Group chat state queries and events.
*
******************************************************************************/
/**
* General error codes for group state get and size functions.
*/
typedef enum Tox_Err_Group_State_Queries {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_STATE_QUERIES_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_STATE_QUERIES_GROUP_NOT_FOUND,
} Tox_Err_Group_State_Queries;
/**
* Error codes for group topic setting.
*/
typedef enum Tox_Err_Group_Topic_Set {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_TOPIC_SET_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_TOPIC_SET_GROUP_NOT_FOUND,
/**
* Topic length exceeded TOX_GROUP_MAX_TOPIC_LENGTH.
*/
TOX_ERR_GROUP_TOPIC_SET_TOO_LONG,
/**
* The caller does not have the required permissions to set the topic.
*/
TOX_ERR_GROUP_TOPIC_SET_PERMISSIONS,
/**
* The packet could not be created. This error is usually related to cryptographic signing.
*/
TOX_ERR_GROUP_TOPIC_SET_FAIL_CREATE,
/**
* The packet failed to send.
*/
TOX_ERR_GROUP_TOPIC_SET_FAIL_SEND,
/**
* The group is disconnected.
*/
TOX_ERR_GROUP_TOPIC_SET_DISCONNECTED,
} Tox_Err_Group_Topic_Set;
/**
* Set the group topic and broadcast it to the rest of the group.
*
* topic length cannot be longer than TOX_GROUP_MAX_TOPIC_LENGTH. If length is equal to zero or
* topic is set to NULL, the topic will be unset.
*
* @return true on success.
*/
bool tox_group_set_topic(const Tox *tox, uint32_t group_number, const uint8_t *topic, size_t length,
Tox_Err_Group_Topic_Set *error);
/**
* Return the length of the group topic. If the group number is invalid, the
* return value is unspecified.
*
* The return value is equal to the `length` argument received by the last
* `group_topic` callback.
*/
size_t tox_group_get_topic_size(const Tox *tox, uint32_t group_number, Tox_Err_Group_State_Queries *error);
/**
* Write the topic designated by the given group number to a byte array.
*
* Call tox_group_get_topic_size to determine the allocation size for the `topic` parameter.
*
* The data written to `topic` is equal to the data received by the last
* `group_topic` callback.
*
* @param topic A valid memory region large enough to store the topic.
* If this parameter is NULL, this function has no effect.
*
* @return true on success.
*/
bool tox_group_get_topic(const Tox *tox, uint32_t group_number, uint8_t *topic, Tox_Err_Group_State_Queries *error);
/**
* @param group_number The group number of the group the topic change is intended for.
* @param peer_id The ID of the peer who changed the topic. If the peer who set the topic
* is not present in our peer list this value will be set to 0.
* @param topic The topic data.
* @param length The topic length.
*/
typedef void tox_group_topic_cb(Tox *tox, uint32_t group_number, uint32_t peer_id, const uint8_t *topic, size_t length,
void *user_data);
/**
* Set the callback for the `group_topic` event. Pass NULL to unset.
*
* This event is triggered when a peer changes the group topic.
*/
void tox_callback_group_topic(Tox *tox, tox_group_topic_cb *callback);
/**
* Return the length of the group name. If the group number is invalid, the
* return value is unspecified.
*/
size_t tox_group_get_name_size(const Tox *tox, uint32_t group_number, Tox_Err_Group_State_Queries *error);
/**
* Write the name of the group designated by the given group number to a byte array.
*
* Call tox_group_get_name_size to determine the allocation size for the `name` parameter.
*
* @param group_name A valid memory region large enough to store the group name.
* If this parameter is NULL, this function call has no effect.
*
* @return true on success.
*/
bool tox_group_get_name(const Tox *tox, uint32_t group_number, uint8_t *group_name, Tox_Err_Group_State_Queries *error);
/**
* Write the Chat ID designated by the given group number to a byte array.
*
* `chat_id` should have room for at least TOX_GROUP_CHAT_ID_SIZE bytes.
*
* @param chat_id A valid memory region large enough to store the Chat ID.
* If this parameter is NULL, this function call has no effect.
*
* @return true on success.
*/
bool tox_group_get_chat_id(const Tox *tox, uint32_t group_number, uint8_t *chat_id, Tox_Err_Group_State_Queries *error);
/**
* Return the number of groups in the Tox chats array.
*/
uint32_t tox_group_get_number_groups(const Tox *tox);
/**
* Return the privacy state of the group designated by the given group number. If group number
* is invalid, the return value is unspecified.
*
* The value returned is equal to the data received by the last
* `group_privacy_state` callback.
*
* @see the `Group chat founder controls` section for the respective set function.
*/
Tox_Group_Privacy_State tox_group_get_privacy_state(const Tox *tox, uint32_t group_number,
Tox_Err_Group_State_Queries *error);
/**
* @param group_number The group number of the group the privacy state is intended for.
* @param privacy_state The new privacy state.
*/
typedef void tox_group_privacy_state_cb(Tox *tox, uint32_t group_number, Tox_Group_Privacy_State privacy_state,
void *user_data);
/**
* Set the callback for the `group_privacy_state` event. Pass NULL to unset.
*
* This event is triggered when the group founder changes the privacy state.
*/
void tox_callback_group_privacy_state(Tox *tox, tox_group_privacy_state_cb *callback);
/**
* Return the voice state of the group designated by the given group number. If group number
* is invalid, the return value is unspecified.
*
* The value returned is equal to the data received by the last `group_voice_state` callback.
*
* @see the `Group chat founder controls` section for the respective set function.
*/
Tox_Group_Voice_State tox_group_get_voice_state(const Tox *tox, uint32_t group_number,
Tox_Err_Group_State_Queries *error);
/**
* @param group_number The group number of the group the voice state change is intended for.
* @param voice_state The new voice state.
*/
typedef void tox_group_voice_state_cb(Tox *tox, uint32_t group_number, Tox_Group_Voice_State voice_state,
void *user_data);
/**
* Set the callback for the `group_privacy_state` event. Pass NULL to unset.
*
* This event is triggered when the group founder changes the voice state.
*/
void tox_callback_group_voice_state(Tox *tox, tox_group_voice_state_cb *callback);
/**
* Return the topic lock status of the group designated by the given group number. If group number
* is invalid, the return value is unspecified.
*
* The value returned is equal to the data received by the last
* `group_topic_lock` callback.
*
* @see the `Group chat founder contols` section for the respective set function.
*/
Tox_Group_Topic_Lock tox_group_get_topic_lock(const Tox *tox, uint32_t group_number,
Tox_Err_Group_State_Queries *error);
/**
* @param group_number The group number of the group for which the topic lock has changed.
* @param topic_lock The new topic lock state.
*/
typedef void tox_group_topic_lock_cb(Tox *tox, uint32_t group_number, Tox_Group_Topic_Lock topic_lock, void *user_data);
/**
* Set the callback for the `group_topic_lock` event. Pass NULL to unset.
*
* This event is triggered when the group founder changes the topic lock status.
*/
void tox_callback_group_topic_lock(Tox *tox, tox_group_topic_lock_cb *callback);
/**
* Return the maximum number of peers allowed for the group designated by the given group number.
* If the group number is invalid, the return value is unspecified.
*
* The value returned is equal to the data received by the last
* `group_peer_limit` callback.
*
* @see the `Group chat founder controls` section for the respective set function.
*/
uint16_t tox_group_get_peer_limit(const Tox *tox, uint32_t group_number, Tox_Err_Group_State_Queries *error);
/**
* @param group_number The group number of the group for which the peer limit has changed.
* @param peer_limit The new peer limit for the group.
*/
typedef void tox_group_peer_limit_cb(Tox *tox, uint32_t group_number, uint32_t peer_limit, void *user_data);
/**
* Set the callback for the `group_peer_limit` event. Pass NULL to unset.
*
* This event is triggered when the group founder changes the maximum peer limit.
*/
void tox_callback_group_peer_limit(Tox *tox, tox_group_peer_limit_cb *callback);
/**
* Return the length of the group password. If the group number is invalid, the
* return value is unspecified.
*/
size_t tox_group_get_password_size(const Tox *tox, uint32_t group_number, Tox_Err_Group_State_Queries *error);
/**
* Write the password for the group designated by the given group number to a byte array.
*
* Call tox_group_get_password_size to determine the allocation size for the `password` parameter.
*
* The data received is equal to the data received by the last
* `group_password` callback.
*
* @see the `Group chat founder controls` section for the respective set function.
*
* @param password A valid memory region large enough to store the group password.
* If this parameter is NULL, this function call has no effect.
*
* @return true on success.
*/
bool tox_group_get_password(const Tox *tox, uint32_t group_number, uint8_t *password,
Tox_Err_Group_State_Queries *error);
/**
* @param group_number The group number of the group for which the password has changed.
* @param password The new group password.
* @param length The length of the password.
*/
typedef void tox_group_password_cb(Tox *tox, uint32_t group_number, const uint8_t *password, size_t length,
void *user_data);
/**
* Set the callback for the `group_password` event. Pass NULL to unset.
*
* This event is triggered when the group founder changes the group password.
*/
void tox_callback_group_password(Tox *tox, tox_group_password_cb *callback);
/*******************************************************************************
*
* :: Group chat message sending
*
******************************************************************************/
typedef enum Tox_Err_Group_Send_Message {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_SEND_MESSAGE_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_SEND_MESSAGE_GROUP_NOT_FOUND,
/**
* Message length exceeded TOX_GROUP_MAX_MESSAGE_LENGTH.
*/
TOX_ERR_GROUP_SEND_MESSAGE_TOO_LONG,
/**
* The message pointer is null or length is zero.
*/
TOX_ERR_GROUP_SEND_MESSAGE_EMPTY,
/**
* The message type is invalid.
*/
TOX_ERR_GROUP_SEND_MESSAGE_BAD_TYPE,
/**
* The caller does not have the required permissions to send group messages.
*/
TOX_ERR_GROUP_SEND_MESSAGE_PERMISSIONS,
/**
* Packet failed to send.
*/
TOX_ERR_GROUP_SEND_MESSAGE_FAIL_SEND,
/**
* The group is disconnected.
*/
TOX_ERR_GROUP_SEND_MESSAGE_DISCONNECTED,
} Tox_Err_Group_Send_Message;
/**
* Send a text chat message to the group.
*
* This function creates a group message packet and pushes it into the send
* queue.
*
* The message length may not exceed TOX_GROUP_MAX_MESSAGE_LENGTH. Larger messages
* must be split by the client and sent as separate messages. Other clients can
* then reassemble the fragments. Messages may not be empty.
*
* @param group_number The group number of the group the message is intended for.
* @param type Message type (normal, action, ...).
* @param message A non-NULL pointer to the first element of a byte array
* containing the message text.
* @param length Length of the message to be sent.
* @param message_id A pointer to a uint32_t. The message_id of this message will be returned
* unless the parameter is NULL, in which case the returned parameter value will be undefined.
* If this function returns false the returned parameter `message_id` value will also be undefined.
*
* @return true on success.
*/
bool tox_group_send_message(const Tox *tox, uint32_t group_number, Tox_Message_Type type, const uint8_t *message,
size_t length, uint32_t *message_id, Tox_Err_Group_Send_Message *error);
typedef enum Tox_Err_Group_Send_Private_Message {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_SEND_PRIVATE_MESSAGE_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_SEND_PRIVATE_MESSAGE_GROUP_NOT_FOUND,
/**
* The peer ID passed did not designate a valid peer.
*/
TOX_ERR_GROUP_SEND_PRIVATE_MESSAGE_PEER_NOT_FOUND,
/**
* Message length exceeded TOX_GROUP_MAX_MESSAGE_LENGTH.
*/
TOX_ERR_GROUP_SEND_PRIVATE_MESSAGE_TOO_LONG,
/**
* The message pointer is null or length is zero.
*/
TOX_ERR_GROUP_SEND_PRIVATE_MESSAGE_EMPTY,
/**
* The caller does not have the required permissions to send group messages.
*/
TOX_ERR_GROUP_SEND_PRIVATE_MESSAGE_PERMISSIONS,
/**
* Packet failed to send.
*/
TOX_ERR_GROUP_SEND_PRIVATE_MESSAGE_FAIL_SEND,
/**
* The group is disconnected.
*/
TOX_ERR_GROUP_SEND_PRIVATE_MESSAGE_DISCONNECTED,
/**
* The message type is invalid.
*/
TOX_ERR_GROUP_SEND_PRIVATE_MESSAGE_BAD_TYPE,
} Tox_Err_Group_Send_Private_Message;
/**
* Send a text chat message to the specified peer in the specified group.
*
* This function creates a group private message packet and pushes it into the send
* queue.
*
* The message length may not exceed TOX_GROUP_MAX_MESSAGE_LENGTH. Larger messages
* must be split by the client and sent as separate messages. Other clients can
* then reassemble the fragments. Messages may not be empty.
*
* @param group_number The group number of the group the message is intended for.
* @param peer_id The ID of the peer the message is intended for.
* @param message A non-NULL pointer to the first element of a byte array
* containing the message text.
* @param length Length of the message to be sent.
*
* @return true on success.
*/
bool tox_group_send_private_message(const Tox *tox, uint32_t group_number, uint32_t peer_id, Tox_Message_Type type,
const uint8_t *message, size_t length, Tox_Err_Group_Send_Private_Message *error);
typedef enum Tox_Err_Group_Send_Custom_Packet {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PACKET_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PACKET_GROUP_NOT_FOUND,
/**
* Message length exceeded TOX_GROUP_MAX_CUSTOM_LOSSY_PACKET_LENGTH if the
* packet was lossy, or TOX_GROUP_MAX_CUSTOM_LOSSLESS_PACKET_LENGTH if the
* packet was lossless.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PACKET_TOO_LONG,
/**
* The message pointer is null or length is zero.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PACKET_EMPTY,
/**
* The caller does not have the required permissions to send group messages.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PACKET_PERMISSIONS,
/**
* The group is disconnected.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PACKET_DISCONNECTED,
} Tox_Err_Group_Send_Custom_Packet;
/**
* Send a custom packet to the group.
*
* If lossless is true the packet will be lossless. Lossless packet behaviour is comparable
* to TCP (reliability, arrive in order) but with packets instead of a stream.
*
* If lossless is false, the packet will be lossy. Lossy packets behave like UDP packets,
* meaning they might never reach the other side or might arrive more than once (if someone
* is messing with the connection) or might arrive in the wrong order.
*
* Unless latency is an issue or message reliability is not important, it is recommended that you use
* lossless packets.
*
* The message length may not exceed TOX_MAX_CUSTOM_PACKET_SIZE. Larger packets
* must be split by the client and sent as separate packets. Other clients can
* then reassemble the fragments. Packets may not be empty.
*
* @param group_number The group number of the group the packet is intended for.
* @param lossless True if the packet should be lossless.
* @param data A byte array containing the packet data.
* @param length The length of the packet data byte array.
*
* @return true on success.
*/
bool tox_group_send_custom_packet(const Tox *tox, uint32_t group_number, bool lossless, const uint8_t *data,
size_t length,
Tox_Err_Group_Send_Custom_Packet *error);
typedef enum Tox_Err_Group_Send_Custom_Private_Packet {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PRIVATE_PACKET_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PRIVATE_PACKET_GROUP_NOT_FOUND,
/**
* Message length exceeded TOX_GROUP_MAX_CUSTOM_LOSSY_PACKET_LENGTH if the
* packet was lossy, or TOX_GROUP_MAX_CUSTOM_LOSSLESS_PACKET_LENGTH if the
* packet was lossless.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PRIVATE_PACKET_TOO_LONG,
/**
* The message pointer is null or length is zero.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PRIVATE_PACKET_EMPTY,
/**
* The peer ID passed did no designate a valid peer.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PRIVATE_PACKET_PEER_NOT_FOUND,
/**
* The caller does not have the required permissions to send group messages.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PRIVATE_PACKET_PERMISSIONS,
/**
* The packet failed to send.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PRIVATE_PACKET_FAIL_SEND,
/**
* The group is disconnected.
*/
TOX_ERR_GROUP_SEND_CUSTOM_PRIVATE_PACKET_DISCONNECTED,
} Tox_Err_Group_Send_Custom_Private_Packet;
/**
* Send a custom private packet to a designated peer in the group.
*
* If lossless is true the packet will be lossless. Lossless packet behaviour is comparable
* to TCP (reliability, arrive in order) but with packets instead of a stream.
*
* If lossless is false, the packet will be lossy. Lossy packets behave like UDP packets,
* meaning they might never reach the other side or might arrive more than once (if someone
* is messing with the connection) or might arrive in the wrong order.
*
* Unless latency is an issue or message reliability is not important, it is recommended that you use
* lossless packets.
*
* The packet length may not exceed TOX_MAX_CUSTOM_PACKET_SIZE. Larger packets
* must be split by the client and sent as separate packets. Other clients can
* then reassemble the fragments. Packets may not be empty.
*
* @param group_number The group number of the group the packet is intended for.
* @param peer_id The ID of the peer the packet is intended for.
* @param lossless True if the packet should be lossless.
* @param data A byte array containing the packet data.
* @param length The length of the packet data byte array.
*
* @return true on success.
*/
bool tox_group_send_custom_private_packet(const Tox *tox, uint32_t group_number, uint32_t peer_id, bool lossless,
const uint8_t *data, size_t length,
Tox_Err_Group_Send_Custom_Private_Packet *error);
/*******************************************************************************
*
* :: Group chat message receiving
*
******************************************************************************/
/**
* @param group_number The group number of the group the message is intended for.
* @param peer_id The ID of the peer who sent the message.
* @param type The type of message (normal, action, ...).
* @param message The message data.
* @param message_id A pseudo message id that clients can use to uniquely identify this group message.
* @param length The length of the message.
*/
typedef void tox_group_message_cb(Tox *tox, uint32_t group_number, uint32_t peer_id, Tox_Message_Type type,
const uint8_t *message, size_t length, uint32_t message_id, void *user_data);
/**
* Set the callback for the `group_message` event. Pass NULL to unset.
*
* This event is triggered when the client receives a group message.
*/
void tox_callback_group_message(Tox *tox, tox_group_message_cb *callback);
/**
* @param group_number The group number of the group the private message is intended for.
* @param peer_id The ID of the peer who sent the private message.
* @param message The message data.
* @param length The length of the message.
*/
typedef void tox_group_private_message_cb(Tox *tox, uint32_t group_number, uint32_t peer_id, Tox_Message_Type type,
const uint8_t *message, size_t length, void *user_data);
/**
* Set the callback for the `group_private_message` event. Pass NULL to unset.
*
* This event is triggered when the client receives a private message.
*/
void tox_callback_group_private_message(Tox *tox, tox_group_private_message_cb *callback);
/**
* @param group_number The group number of the group the packet is intended for.
* @param peer_id The ID of the peer who sent the packet.
* @param data The packet data.
* @param length The length of the data.
*/
typedef void tox_group_custom_packet_cb(Tox *tox, uint32_t group_number, uint32_t peer_id, const uint8_t *data,
size_t length, void *user_data);
/**
* Set the callback for the `group_custom_packet` event. Pass NULL to unset.
*
* This event is triggered when the client receives a custom packet.
*/
void tox_callback_group_custom_packet(Tox *tox, tox_group_custom_packet_cb *callback);
/**
* @param group_number The group number of the group the packet is intended for.
* @param peer_id The ID of the peer who sent the packet.
* @param data The packet data.
* @param length The length of the data.
*/
typedef void tox_group_custom_private_packet_cb(Tox *tox, uint32_t group_number, uint32_t peer_id, const uint8_t *data,
size_t length, void *user_data);
/**
* Set the callback for the `group_custom_private_packet` event. Pass NULL to unset.
*
* This event is triggered when the client receives a custom private packet.
*/
void tox_callback_group_custom_private_packet(Tox *tox, tox_group_custom_private_packet_cb *callback);
/*******************************************************************************
*
* :: Group chat inviting and join/part events
*
******************************************************************************/
typedef enum Tox_Err_Group_Invite_Friend {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_INVITE_FRIEND_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_INVITE_FRIEND_GROUP_NOT_FOUND,
/**
* The friend number passed did not designate a valid friend.
*/
TOX_ERR_GROUP_INVITE_FRIEND_FRIEND_NOT_FOUND,
/**
* Creation of the invite packet failed. This indicates a network related error.
*/
TOX_ERR_GROUP_INVITE_FRIEND_INVITE_FAIL,
/**
* Packet failed to send.
*/
TOX_ERR_GROUP_INVITE_FRIEND_FAIL_SEND,
/**
* The group is disconnected.
*/
TOX_ERR_GROUP_INVITE_FRIEND_DISCONNECTED,
} Tox_Err_Group_Invite_Friend;
/**
* Invite a friend to a group.
*
* This function creates an invite request packet and pushes it to the send queue.
*
* @param group_number The group number of the group the message is intended for.
* @param friend_number The friend number of the friend the invite is intended for.
*
* @return true on success.
*/
bool tox_group_invite_friend(const Tox *tox, uint32_t group_number, uint32_t friend_number,
Tox_Err_Group_Invite_Friend *error);
typedef enum Tox_Err_Group_Invite_Accept {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_INVITE_ACCEPT_OK,
/**
* The invite data is not in the expected format.
*/
TOX_ERR_GROUP_INVITE_ACCEPT_BAD_INVITE,
/**
* The group instance failed to initialize.
*/
TOX_ERR_GROUP_INVITE_ACCEPT_INIT_FAILED,
/**
* name exceeds TOX_MAX_NAME_LENGTH
*/
TOX_ERR_GROUP_INVITE_ACCEPT_TOO_LONG,
/**
* name is NULL or name_length is zero.
*/
TOX_ERR_GROUP_INVITE_ACCEPT_EMPTY,
/**
* Failed to set password. This usually occurs if the password exceeds TOX_GROUP_MAX_PASSWORD_SIZE.
*/
TOX_ERR_GROUP_INVITE_ACCEPT_PASSWORD,
/**
* There was a core error when initiating the group.
*/
TOX_ERR_GROUP_INVITE_ACCEPT_CORE,
/**
* Packet failed to send.
*/
TOX_ERR_GROUP_INVITE_ACCEPT_FAIL_SEND,
} Tox_Err_Group_Invite_Accept;
/**
* Accept an invite to a group chat that the client previously received from a friend. The invite
* is only valid while the inviter is present in the group.
*
* @param invite_data The invite data received from the `group_invite` event.
* @param length The length of the invite data.
* @param name The name of the peer joining the group.
* @param name_length The length of the peer's name. This must be greater than zero and no larger
* than TOX_MAX_NAME_LENGTH.
* @param password The password required to join the group. Set to NULL if no password is required.
* @param password_length The length of the password. If password_length is equal to zero, the password
* parameter will be ignored. password_length must be no larger than TOX_GROUP_MAX_PASSWORD_SIZE.
*
* @return the group_number on success, UINT32_MAX on failure.
*/
uint32_t tox_group_invite_accept(Tox *tox, uint32_t friend_number, const uint8_t *invite_data, size_t length,
const uint8_t *name, size_t name_length, const uint8_t *password, size_t password_length,
Tox_Err_Group_Invite_Accept *error);
/**
* @param friend_number The friend number of the contact who sent the invite.
* @param invite_data The invite data.
* @param length The length of invite_data.
*/
typedef void tox_group_invite_cb(Tox *tox, uint32_t friend_number, const uint8_t *invite_data, size_t length,
const uint8_t *group_name, size_t group_name_length, void *user_data);
/**
* Set the callback for the `group_invite` event. Pass NULL to unset.
*
* This event is triggered when the client receives a group invite from a friend. The client must store
* invite_data which is used to join the group via tox_group_invite_accept.
*/
void tox_callback_group_invite(Tox *tox, tox_group_invite_cb *callback);
/**
* @param group_number The group number of the group in which a new peer has joined.
* @param peer_id The permanent ID of the new peer. This id should not be relied on for
* client behaviour and should be treated as a random value.
*/
typedef void tox_group_peer_join_cb(Tox *tox, uint32_t group_number, uint32_t peer_id, void *user_data);
/**
* Set the callback for the `group_peer_join` event. Pass NULL to unset.
*
* This event is triggered when a peer other than self joins the group.
*/
void tox_callback_group_peer_join(Tox *tox, tox_group_peer_join_cb *callback);
/**
* Represents peer exit events. These should be used with the `group_peer_exit` event.
*/
typedef enum Tox_Group_Exit_Type {
/**
* The peer has quit the group.
*/
TOX_GROUP_EXIT_TYPE_QUIT,
/**
* Your connection with this peer has timed out.
*/
TOX_GROUP_EXIT_TYPE_TIMEOUT,
/**
* Your connection with this peer has been severed.
*/
TOX_GROUP_EXIT_TYPE_DISCONNECTED,
/**
* Your connection with all peers has been severed. This will occur when you are kicked from
* a group, rejoin a group, or manually disconnect from a group.
*/
TOX_GROUP_EXIT_TYPE_SELF_DISCONNECTED,
/**
* The peer has been kicked.
*/
TOX_GROUP_EXIT_TYPE_KICK,
/**
* The peer provided invalid group sync information.
*/
TOX_GROUP_EXIT_TYPE_SYNC_ERROR,
} Tox_Group_Exit_Type;
/**
* @param group_number The group number of the group in which a peer has left.
* @param peer_id The ID of the peer who left the group. This ID no longer designates a valid peer
* and cannot be used for API calls.
* @param exit_type The type of exit event. One of Tox_Group_Exit_Type.
* @param name The nickname of the peer who left the group.
* @param name_length The length of the peer name.
* @param part_message The parting message data.
* @param part_message_length The length of the parting message.
*/
typedef void tox_group_peer_exit_cb(Tox *tox, uint32_t group_number, uint32_t peer_id, Tox_Group_Exit_Type exit_type,
const uint8_t *name, size_t name_length, const uint8_t *part_message, size_t part_message_length, void *user_data);
/**
* Set the callback for the `group_peer_exit` event. Pass NULL to unset.
*
* This event is triggered when a peer other than self exits the group.
*/
void tox_callback_group_peer_exit(Tox *tox, tox_group_peer_exit_cb *callback);
/**
* @param group_number The group number of the group that the client has joined.
*/
typedef void tox_group_self_join_cb(Tox *tox, uint32_t group_number, void *user_data);
/**
* Set the callback for the `group_self_join` event. Pass NULL to unset.
*
* This event is triggered when the client has successfully joined a group. Use this to initialize
* any group information the client may need.
*/
void tox_callback_group_self_join(Tox *tox, tox_group_self_join_cb *callback);
/**
* Represents types of failed group join attempts. These are used in the tox_callback_group_rejected
* callback when a peer fails to join a group.
*/
typedef enum Tox_Group_Join_Fail {
/**
* The group peer limit has been reached.
*/
TOX_GROUP_JOIN_FAIL_PEER_LIMIT,
/**
* You have supplied an invalid password.
*/
TOX_GROUP_JOIN_FAIL_INVALID_PASSWORD,
/**
* The join attempt failed due to an unspecified error. This often occurs when the group is
* not found in the DHT.
*/
TOX_GROUP_JOIN_FAIL_UNKNOWN,
} Tox_Group_Join_Fail;
/**
* @param group_number The group number of the group for which the join has failed.
* @param fail_type The type of group rejection.
*/
typedef void tox_group_join_fail_cb(Tox *tox, uint32_t group_number, Tox_Group_Join_Fail fail_type, void *user_data);
/**
* Set the callback for the `group_join_fail` event. Pass NULL to unset.
*
* This event is triggered when the client fails to join a group.
*/
void tox_callback_group_join_fail(Tox *tox, tox_group_join_fail_cb *callback);
/*******************************************************************************
*
* :: Group chat founder controls (these only work for the group founder)
*
******************************************************************************/
typedef enum Tox_Err_Group_Founder_Set_Password {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_FOUNDER_SET_PASSWORD_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_FOUNDER_SET_PASSWORD_GROUP_NOT_FOUND,
/**
* The caller does not have the required permissions to set the password.
*/
TOX_ERR_GROUP_FOUNDER_SET_PASSWORD_PERMISSIONS,
/**
* Password length exceeded TOX_GROUP_MAX_PASSWORD_SIZE.
*/
TOX_ERR_GROUP_FOUNDER_SET_PASSWORD_TOO_LONG,
/**
* The packet failed to send.
*/
TOX_ERR_GROUP_FOUNDER_SET_PASSWORD_FAIL_SEND,
/**
* The function failed to allocate enough memory for the operation.
*/
TOX_ERR_GROUP_FOUNDER_SET_PASSWORD_MALLOC,
/**
* The group is disconnected.
*/
TOX_ERR_GROUP_FOUNDER_SET_PASSWORD_DISCONNECTED,
} Tox_Err_Group_Founder_Set_Password;
/**
* Set or unset the group password.
*
* This function sets the groups password, creates a new group shared state including the change,
* and distributes it to the rest of the group.
*
* @param group_number The group number of the group for which we wish to set the password.
* @param password The password we want to set. Set password to NULL to unset the password.
* @param length The length of the password. length must be no longer than TOX_GROUP_MAX_PASSWORD_SIZE.
*
* @return true on success.
*/
bool tox_group_founder_set_password(const Tox *tox, uint32_t group_number, const uint8_t *password, size_t length,
Tox_Err_Group_Founder_Set_Password *error);
typedef enum Tox_Err_Group_Founder_Set_Topic_Lock {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_FOUNDER_SET_TOPIC_LOCK_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_FOUNDER_SET_TOPIC_LOCK_GROUP_NOT_FOUND,
/**
* Tox_Group_Topic_Lock is an invalid type.
*/
TOX_ERR_GROUP_FOUNDER_SET_TOPIC_LOCK_INVALID,
/**
* The caller does not have the required permissions to set the topic lock.
*/
TOX_ERR_GROUP_FOUNDER_SET_TOPIC_LOCK_PERMISSIONS,
/**
* The topic lock could not be set. This may occur due to an error related to
* cryptographic signing of the new shared state.
*/
TOX_ERR_GROUP_FOUNDER_SET_TOPIC_LOCK_FAIL_SET,
/**
* The packet failed to send.
*/
TOX_ERR_GROUP_FOUNDER_SET_TOPIC_LOCK_FAIL_SEND,
/**
* The group is disconnected.
*/
TOX_ERR_GROUP_FOUNDER_SET_TOPIC_LOCK_DISCONNECTED,
} Tox_Err_Group_Founder_Set_Topic_Lock;
/**
* Set the group topic lock state.
*
* This function sets the group's topic lock state to enabled or disabled, creates a new shared
* state including the change, and distributes it to the rest of the group.
*
* When the topic lock is enabled, only the group founder and moderators may set the topic.
* When disabled, all peers except those with the observer role may set the topic.
*
* @param group_number The group number of the group for which we wish to change the topic lock state.
* @param topic_lock The state we wish to set the topic lock to.
*
* @return true on success.
*/
bool tox_group_founder_set_topic_lock(const Tox *tox, uint32_t group_number, Tox_Group_Topic_Lock topic_lock,
Tox_Err_Group_Founder_Set_Topic_Lock *error);
typedef enum Tox_Err_Group_Founder_Set_Voice_State {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_FOUNDER_SET_VOICE_STATE_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_FOUNDER_SET_VOICE_STATE_GROUP_NOT_FOUND,
/**
* The caller does not have the required permissions to set the privacy state.
*/
TOX_ERR_GROUP_FOUNDER_SET_VOICE_STATE_PERMISSIONS,
/**
* The voice state could not be set. This may occur due to an error related to
* cryptographic signing of the new shared state.
*/
TOX_ERR_GROUP_FOUNDER_SET_VOICE_STATE_FAIL_SET,
/**
* The packet failed to send.
*/
TOX_ERR_GROUP_FOUNDER_SET_VOICE_STATE_FAIL_SEND,
/**
* The group is disconnected.
*/
TOX_ERR_GROUP_FOUNDER_SET_VOICE_STATE_DISCONNECTED,
} Tox_Err_Group_Founder_Set_Voice_State;
/**
* Set the group voice state.
*
* This function sets the group's voice state, creates a new group shared state
* including the change, and distributes it to the rest of the group.
*
* If an attempt is made to set the voice state to the same state that the group is already
* in, the function call will be successful and no action will be taken.
*
* @param group_number The group number of the group for which we wish to change the voice state.
* @param voice_state The voice state we wish to set the group to.
*
* @return true on success.
*/
bool tox_group_founder_set_voice_state(const Tox *tox, uint32_t group_number, Tox_Group_Voice_State voice_state,
Tox_Err_Group_Founder_Set_Voice_State *error);
typedef enum Tox_Err_Group_Founder_Set_Privacy_State {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_FOUNDER_SET_PRIVACY_STATE_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_FOUNDER_SET_PRIVACY_STATE_GROUP_NOT_FOUND,
/**
* The caller does not have the required permissions to set the privacy state.
*/
TOX_ERR_GROUP_FOUNDER_SET_PRIVACY_STATE_PERMISSIONS,
/**
* The privacy state could not be set. This may occur due to an error related to
* cryptographic signing of the new shared state.
*/
TOX_ERR_GROUP_FOUNDER_SET_PRIVACY_STATE_FAIL_SET,
/**
* The packet failed to send.
*/
TOX_ERR_GROUP_FOUNDER_SET_PRIVACY_STATE_FAIL_SEND,
/**
* The group is disconnected.
*/
TOX_ERR_GROUP_FOUNDER_SET_PRIVACY_STATE_DISCONNECTED,
} Tox_Err_Group_Founder_Set_Privacy_State;
/**
* Set the group privacy state.
*
* This function sets the group's privacy state, creates a new group shared state
* including the change, and distributes it to the rest of the group.
*
* If an attempt is made to set the privacy state to the same state that the group is already
* in, the function call will be successful and no action will be taken.
*
* @param group_number The group number of the group for which we wish to change the privacy state.
* @param privacy_state The privacy state we wish to set the group to.
*
* @return true on success.
*/
bool tox_group_founder_set_privacy_state(const Tox *tox, uint32_t group_number, Tox_Group_Privacy_State privacy_state,
Tox_Err_Group_Founder_Set_Privacy_State *error);
typedef enum Tox_Err_Group_Founder_Set_Peer_Limit {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_FOUNDER_SET_PEER_LIMIT_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_FOUNDER_SET_PEER_LIMIT_GROUP_NOT_FOUND,
/**
* The caller does not have the required permissions to set the peer limit.
*/
TOX_ERR_GROUP_FOUNDER_SET_PEER_LIMIT_PERMISSIONS,
/**
* The peer limit could not be set. This may occur due to an error related to
* cryptographic signing of the new shared state.
*/
TOX_ERR_GROUP_FOUNDER_SET_PEER_LIMIT_FAIL_SET,
/**
* The packet failed to send.
*/
TOX_ERR_GROUP_FOUNDER_SET_PEER_LIMIT_FAIL_SEND,
/**
* The group is disconnected.
*/
TOX_ERR_GROUP_FOUNDER_SET_PEER_LIMIT_DISCONNECTED,
} Tox_Err_Group_Founder_Set_Peer_Limit;
/**
* Set the group peer limit.
*
* This function sets a limit for the number of peers who may be in the group, creates a new
* group shared state including the change, and distributes it to the rest of the group.
*
* @param group_number The group number of the group for which we wish to set the peer limit.
* @param max_peers The maximum number of peers to allow in the group.
*
* @return true on success.
*/
bool tox_group_founder_set_peer_limit(const Tox *tox, uint32_t group_number, uint16_t max_peers,
Tox_Err_Group_Founder_Set_Peer_Limit *error);
/*******************************************************************************
*
* :: Group chat moderation
*
******************************************************************************/
typedef enum Tox_Err_Group_Set_Ignore {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_SET_IGNORE_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_SET_IGNORE_GROUP_NOT_FOUND,
/**
* The ID passed did not designate a valid peer.
*/
TOX_ERR_GROUP_SET_IGNORE_PEER_NOT_FOUND,
/**
* The caller attempted to ignore himself.
*/
TOX_ERR_GROUP_SET_IGNORE_SELF,
} Tox_Err_Group_Set_Ignore;
/**
* Ignore or unignore a peer.
*
* @param group_number The group number of the group in which you wish to ignore a peer.
* @param peer_id The ID of the peer who shall be ignored or unignored.
* @param ignore True to ignore the peer, false to unignore the peer.
*
* @return true on success.
*/
bool tox_group_set_ignore(const Tox *tox, uint32_t group_number, uint32_t peer_id, bool ignore,
Tox_Err_Group_Set_Ignore *error);
typedef enum Tox_Err_Group_Mod_Set_Role {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_MOD_SET_ROLE_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_MOD_SET_ROLE_GROUP_NOT_FOUND,
/**
* The ID passed did not designate a valid peer. Note: you cannot set your own role.
*/
TOX_ERR_GROUP_MOD_SET_ROLE_PEER_NOT_FOUND,
/**
* The caller does not have the required permissions for this action.
*/
TOX_ERR_GROUP_MOD_SET_ROLE_PERMISSIONS,
/**
* The role assignment is invalid. This will occur if you try to set a peer's role to
* the role they already have.
*/
TOX_ERR_GROUP_MOD_SET_ROLE_ASSIGNMENT,
/**
* The role was not successfully set. This may occur if the packet failed to send, or
* if the role limit has been reached.
*/
TOX_ERR_GROUP_MOD_SET_ROLE_FAIL_ACTION,
/**
* The caller attempted to set their own role.
*/
TOX_ERR_GROUP_MOD_SET_ROLE_SELF,
} Tox_Err_Group_Mod_Set_Role;
/**
* Set a peer's role.
*
* This function will first remove the peer's previous role and then assign them a new role.
* It will also send a packet to the rest of the group, requesting that they perform
* the role reassignment. Note: peers cannot be set to the founder role.
*
* @param group_number The group number of the group the in which you wish set the peer's role.
* @param peer_id The ID of the peer whose role you wish to set.
* @param role The role you wish to set the peer to.
*
* @return true on success.
*/
bool tox_group_mod_set_role(const Tox *tox, uint32_t group_number, uint32_t peer_id, Tox_Group_Role role,
Tox_Err_Group_Mod_Set_Role *error);
typedef enum Tox_Err_Group_Mod_Kick_Peer {
/**
* The function returned successfully.
*/
TOX_ERR_GROUP_MOD_KICK_PEER_OK,
/**
* The group number passed did not designate a valid group.
*/
TOX_ERR_GROUP_MOD_KICK_PEER_GROUP_NOT_FOUND,
/**
* The ID passed did not designate a valid peer.
*/
TOX_ERR_GROUP_MOD_KICK_PEER_PEER_NOT_FOUND,
/**
* The caller does not have the required permissions for this action.
*/
TOX_ERR_GROUP_MOD_KICK_PEER_PERMISSIONS,
/**
* The peer could not be kicked from the group.
*/
TOX_ERR_GROUP_MOD_KICK_PEER_FAIL_ACTION,
/**
* The packet failed to send.
*/
TOX_ERR_GROUP_MOD_KICK_PEER_FAIL_SEND,
/**
* The caller attempted to set their own role.
*/
TOX_ERR_GROUP_MOD_KICK_PEER_SELF,
} Tox_Err_Group_Mod_Kick_Peer;
/**
* Kick a peer.
*
* This function will remove a peer from the caller's peer list and send a packet to all
* group members requesting them to do the same. Note: This function will not trigger
* the `group_peer_exit` event for the caller.
*
* @param group_number The group number of the group the action is intended for.
* @param peer_id The ID of the peer who will be kicked.
*
* @return true on success.
*/
bool tox_group_mod_kick_peer(const Tox *tox, uint32_t group_number, uint32_t peer_id,
Tox_Err_Group_Mod_Kick_Peer *error);
/**
* Represents moderation events. These should be used with the `group_moderation` event.
*/
typedef enum Tox_Group_Mod_Event {
/**
* A peer has been kicked from the group.
*/
TOX_GROUP_MOD_EVENT_KICK,
/**
* A peer as been given the observer role.
*/
TOX_GROUP_MOD_EVENT_OBSERVER,
/**
* A peer has been given the user role.
*/
TOX_GROUP_MOD_EVENT_USER,
/**
* A peer has been given the moderator role.
*/
TOX_GROUP_MOD_EVENT_MODERATOR,
} Tox_Group_Mod_Event;
/**
* @param group_number The group number of the group the event is intended for.
* @param source_peer_id The ID of the peer who initiated the event.
* @param target_peer_id The ID of the peer who is the target of the event.
* @param mod_type The type of event.
*/
typedef void tox_group_moderation_cb(Tox *tox, uint32_t group_number, uint32_t source_peer_id, uint32_t target_peer_id,
Tox_Group_Mod_Event mod_type, void *user_data);
/**
* Set the callback for the `group_moderation` event. Pass NULL to unset.
*
* This event is triggered when a moderator or founder executes a moderation event, with
* the exception of the peer who initiates the event. It is also triggered when the
* observer and moderator lists are silently modified (this may occur during group syncing).
*
* If either peer id does not designate a valid peer in the group chat, the client should
* manually update all peer roles.
*/
void tox_callback_group_moderation(Tox *tox, tox_group_moderation_cb *callback);
/** @} */
/** @} */
#ifdef __cplusplus
}
#endif
//!TOKSTYLE-
#ifndef DOXYGEN_IGNORE
typedef Tox_Err_Options_New TOX_ERR_OPTIONS_NEW;
typedef Tox_Err_New TOX_ERR_NEW;
typedef Tox_Err_Bootstrap TOX_ERR_BOOTSTRAP;
typedef Tox_Err_Set_Info TOX_ERR_SET_INFO;
typedef Tox_Err_Friend_Add TOX_ERR_FRIEND_ADD;
typedef Tox_Err_Friend_Delete TOX_ERR_FRIEND_DELETE;
typedef Tox_Err_Friend_By_Public_Key TOX_ERR_FRIEND_BY_PUBLIC_KEY;
typedef Tox_Err_Friend_Get_Public_Key TOX_ERR_FRIEND_GET_PUBLIC_KEY;
typedef Tox_Err_Friend_Get_Last_Online TOX_ERR_FRIEND_GET_LAST_ONLINE;
typedef Tox_Err_Friend_Query TOX_ERR_FRIEND_QUERY;
typedef Tox_Err_Set_Typing TOX_ERR_SET_TYPING;
typedef Tox_Err_Friend_Send_Message TOX_ERR_FRIEND_SEND_MESSAGE;
typedef Tox_Err_File_Control TOX_ERR_FILE_CONTROL;
typedef Tox_Err_File_Seek TOX_ERR_FILE_SEEK;
typedef Tox_Err_File_Get TOX_ERR_FILE_GET;
typedef Tox_Err_File_Send TOX_ERR_FILE_SEND;
typedef Tox_Err_File_Send_Chunk TOX_ERR_FILE_SEND_CHUNK;
typedef Tox_Err_Conference_New TOX_ERR_CONFERENCE_NEW;
typedef Tox_Err_Conference_Delete TOX_ERR_CONFERENCE_DELETE;
typedef Tox_Err_Conference_Peer_Query TOX_ERR_CONFERENCE_PEER_QUERY;
typedef Tox_Err_Conference_Set_Max_Offline TOX_ERR_CONFERENCE_SET_MAX_OFFLINE;
typedef Tox_Err_Conference_By_Id TOX_ERR_CONFERENCE_BY_ID;
typedef Tox_Err_Conference_By_Uid TOX_ERR_CONFERENCE_BY_UID;
typedef Tox_Err_Conference_Invite TOX_ERR_CONFERENCE_INVITE;
typedef Tox_Err_Conference_Join TOX_ERR_CONFERENCE_JOIN;
typedef Tox_Err_Conference_Send_Message TOX_ERR_CONFERENCE_SEND_MESSAGE;
typedef Tox_Err_Conference_Title TOX_ERR_CONFERENCE_TITLE;
typedef Tox_Err_Conference_Get_Type TOX_ERR_CONFERENCE_GET_TYPE;
typedef Tox_Err_Friend_Custom_Packet TOX_ERR_FRIEND_CUSTOM_PACKET;
typedef Tox_Err_Get_Port TOX_ERR_GET_PORT;
typedef Tox_User_Status TOX_USER_STATUS;
typedef Tox_Message_Type TOX_MESSAGE_TYPE;
typedef Tox_Proxy_Type TOX_PROXY_TYPE;
typedef Tox_Savedata_Type TOX_SAVEDATA_TYPE;
typedef Tox_Log_Level TOX_LOG_LEVEL;
typedef Tox_Connection TOX_CONNECTION;
typedef Tox_File_Control TOX_FILE_CONTROL;
typedef Tox_Conference_Type TOX_CONFERENCE_TYPE;
typedef enum Tox_File_Kind TOX_FILE_KIND;
#endif
//!TOKSTYLE+
#endif // C_TOXCORE_TOXCORE_TOX_H
|