diff options
-rw-r--r-- | core/network.c | 43 | ||||
-rw-r--r-- | core/network.h | 10 | ||||
-rw-r--r-- | core/tox.h | 146 | ||||
-rw-r--r-- | other/bootstrap_serverdaemon/DHT_bootstrap_daemon.c | 41 | ||||
-rw-r--r-- | testing/nTox.c | 98 | ||||
-rw-r--r-- | testing/nTox.h | 46 |
6 files changed, 219 insertions, 165 deletions
diff --git a/core/network.c b/core/network.c index 7880eae6..2bcf7d61 100644 --- a/core/network.c +++ b/core/network.c | |||
@@ -144,8 +144,9 @@ static void at_shutdown(void) | |||
144 | returns NULL if there are problems */ | 144 | returns NULL if there are problems */ |
145 | Networking_Core *new_networking(IP ip, uint16_t port) | 145 | Networking_Core *new_networking(IP ip, uint16_t port) |
146 | { | 146 | { |
147 | if(at_startup() != 0) | 147 | if (at_startup() != 0) |
148 | return NULL; | 148 | return NULL; |
149 | |||
149 | /* initialize our socket */ | 150 | /* initialize our socket */ |
150 | Networking_Core *temp = calloc(1, sizeof(Networking_Core)); | 151 | Networking_Core *temp = calloc(1, sizeof(Networking_Core)); |
151 | 152 | ||
@@ -215,43 +216,3 @@ void kill_networking(Networking_Core *net) | |||
215 | free(net); | 216 | free(net); |
216 | return; | 217 | return; |
217 | } | 218 | } |
218 | |||
219 | /* | ||
220 | resolve_addr(): | ||
221 | address should represent IPv4 or a hostname with A record | ||
222 | |||
223 | returns a data in network byte order that can be used to set IP.i or IP_Port.ip.i | ||
224 | returns 0 on failure | ||
225 | |||
226 | TODO: Fix ipv6 support | ||
227 | */ | ||
228 | uint32_t resolve_addr(const char *address) | ||
229 | { | ||
230 | struct addrinfo *server = NULL; | ||
231 | struct addrinfo hints; | ||
232 | int rc; | ||
233 | uint32_t addr; | ||
234 | |||
235 | memset(&hints, 0, sizeof(hints)); | ||
236 | hints.ai_family = AF_INET; // IPv4 only right now. | ||
237 | hints.ai_socktype = SOCK_DGRAM; // type of socket Tox uses. | ||
238 | |||
239 | rc = getaddrinfo(address, "echo", &hints, &server); | ||
240 | |||
241 | // Lookup failed. | ||
242 | if (rc != 0) { | ||
243 | return 0; | ||
244 | } | ||
245 | |||
246 | // IPv4 records only.. | ||
247 | if (server->ai_family != AF_INET) { | ||
248 | freeaddrinfo(server); | ||
249 | return 0; | ||
250 | } | ||
251 | |||
252 | |||
253 | addr = ((struct sockaddr_in *)server->ai_addr)->sin_addr.s_addr; | ||
254 | |||
255 | freeaddrinfo(server); | ||
256 | return addr; | ||
257 | } | ||
diff --git a/core/network.h b/core/network.h index 088bbb3b..3547f79b 100644 --- a/core/network.h +++ b/core/network.h | |||
@@ -151,16 +151,6 @@ Networking_Core *new_networking(IP ip, uint16_t port); | |||
151 | /* function to cleanup networking stuff(doesn't do much right now) */ | 151 | /* function to cleanup networking stuff(doesn't do much right now) */ |
152 | void kill_networking(Networking_Core *net); | 152 | void kill_networking(Networking_Core *net); |
153 | 153 | ||
154 | /* | ||
155 | resolve_addr(): | ||
156 | address should represent IPv4 or a hostname with A record | ||
157 | |||
158 | returns a data in network byte order that can be used to set IP.i or IP_Port.ip.i | ||
159 | returns 0 on failure | ||
160 | |||
161 | TODO: Fix ipv6 support | ||
162 | */ | ||
163 | uint32_t resolve_addr(const char *address); | ||
164 | 154 | ||
165 | #ifdef __cplusplus | 155 | #ifdef __cplusplus |
166 | } | 156 | } |
@@ -24,34 +24,53 @@ | |||
24 | #ifndef TOX_H | 24 | #ifndef TOX_H |
25 | #define TOX_H | 25 | #define TOX_H |
26 | 26 | ||
27 | #include <stdint.h> | ||
27 | 28 | ||
28 | #ifdef __cplusplus | 29 | #ifdef __cplusplus |
29 | extern "C" { | 30 | extern "C" { |
30 | #endif | 31 | #endif |
31 | 32 | ||
32 | #define MAX_NAME_LENGTH 128 | 33 | #define TOX_MAX_NAME_LENGTH 128 |
33 | #define MAX_STATUSMESSAGE_LENGTH 128 | 34 | #define TOX_MAX_STATUSMESSAGE_LENGTH 128 |
35 | #define TOX_CLIENT_ID_SIZE 32 | ||
34 | 36 | ||
35 | #define FRIEND_ADDRESS_SIZE (crypto_box_PUBLICKEYBYTES + sizeof(uint32_t) + sizeof(uint16_t)) | 37 | #define TOX_FRIEND_ADDRESS_SIZE (TOX_CLIENT_ID_SIZE + sizeof(uint32_t) + sizeof(uint16_t)) |
38 | |||
39 | |||
40 | typedef union { | ||
41 | uint8_t c[4]; | ||
42 | uint16_t s[2]; | ||
43 | uint32_t i; | ||
44 | } IP; | ||
45 | |||
46 | typedef struct { | ||
47 | IP ip; | ||
48 | uint16_t port; | ||
49 | /* not used for anything right now */ | ||
50 | uint16_t padding; | ||
51 | } IP_Port; | ||
36 | 52 | ||
37 | /* status definitions */ | 53 | /* status definitions */ |
38 | #define FRIEND_ONLINE 4 | 54 | enum { |
39 | #define FRIEND_CONFIRMED 3 | 55 | TOX_NOFRIEND, |
40 | #define FRIEND_REQUESTED 2 | 56 | TOX_FRIEND_ADDED, |
41 | #define FRIEND_ADDED 1 | 57 | TOX_FRIEND_REQUESTED, |
42 | #define NOFRIEND 0 | 58 | TOX_FRIEND_CONFIRMED, |
59 | TOX_FRIEND_ONLINE, | ||
60 | }; | ||
43 | 61 | ||
44 | /* errors for m_addfriend | 62 | /* errors for m_addfriend |
45 | * FAERR - Friend Add Error */ | 63 | * FAERR - Friend Add Error */ |
46 | #define FAERR_TOOLONG -1 | 64 | enum { |
47 | #define FAERR_NOMESSAGE -2 | 65 | TOX_FAERR_TOOLONG = -1, |
48 | #define FAERR_OWNKEY -3 | 66 | TOX_FAERR_NOMESSAGE = -2, |
49 | #define FAERR_ALREADYSENT -4 | 67 | TOX_FAERR_OWNKEY = -3, |
50 | #define FAERR_UNKNOWN -5 | 68 | TOX_FAERR_ALREADYSENT = -4, |
51 | #define FAERR_BADCHECKSUM -6 | 69 | TOX_FAERR_UNKNOWN = -5, |
52 | #define FAERR_SETNEWNOSPAM -7 | 70 | TOX_FAERR_BADCHECKSUM = -6, |
53 | #define FAERR_NOMEM -8 | 71 | TOX_FAERR_SETNEWNOSPAM = -7, |
54 | 72 | TOX_FAERR_NOMEM = -8 | |
73 | }; | ||
55 | /* USERSTATUS | 74 | /* USERSTATUS |
56 | * Represents userstatuses someone can have. */ | 75 | * Represents userstatuses someone can have. */ |
57 | 76 | ||
@@ -63,12 +82,14 @@ typedef enum { | |||
63 | } | 82 | } |
64 | TOX_USERSTATUS; | 83 | TOX_USERSTATUS; |
65 | 84 | ||
85 | typedef void Tox; | ||
86 | |||
66 | /* | 87 | /* |
67 | * returns a FRIEND_ADDRESS_SIZE byte address to give to others. | 88 | * returns a FRIEND_ADDRESS_SIZE byte address to give to others. |
68 | * format: [client_id (32 bytes)][nospam number (4 bytes)][checksum (2 bytes)] | 89 | * format: [client_id (32 bytes)][nospam number (4 bytes)][checksum (2 bytes)] |
69 | * | 90 | * |
70 | */ | 91 | */ |
71 | void tox_getaddress(void *tox, uint8_t *address); | 92 | void tox_getaddress(Tox *tox, uint8_t *address); |
72 | 93 | ||
73 | /* | 94 | /* |
74 | * add a friend | 95 | * add a friend |
@@ -76,43 +97,43 @@ void tox_getaddress(void *tox, uint8_t *address); | |||
76 | * address is the address of the friend (returned by getaddress of the friend you wish to add) it must be FRIEND_ADDRESS_SIZE bytes. TODO: add checksum. | 97 | * address is the address of the friend (returned by getaddress of the friend you wish to add) it must be FRIEND_ADDRESS_SIZE bytes. TODO: add checksum. |
77 | * data is the data and length is the length | 98 | * data is the data and length is the length |
78 | * returns the friend number if success | 99 | * returns the friend number if success |
79 | * return -1 if message length is too long | 100 | * return FA_TOOLONG if message length is too long |
80 | * return -2 if no message (message length must be >= 1 byte) | 101 | * return FAERR_NOMESSAGE if no message (message length must be >= 1 byte) |
81 | * return -3 if user's own key | 102 | * return FAERR_OWNKEY if user's own key |
82 | * return -4 if friend request already sent or already a friend | 103 | * return FAERR_ALREADYSENT if friend request already sent or already a friend |
83 | * return -5 for unknown error | 104 | * return FAERR_UNKNOWN for unknown error |
84 | * return -6 if bad checksum in address | 105 | * return FAERR_BADCHECKSUM if bad checksum in address |
85 | * return -7 if the friend was already there but the nospam was different | 106 | * return FAERR_SETNEWNOSPAM if the friend was already there but the nospam was different |
86 | * (the nospam for that friend was set to the new one) | 107 | * (the nospam for that friend was set to the new one) |
87 | * return -8 if increasing the friend list size fails | 108 | * return FAERR_NOMEM if increasing the friend list size fails |
88 | */ | 109 | */ |
89 | int tox_addfriend(void *tox, uint8_t *address, uint8_t *data, uint16_t length); | 110 | int tox_addfriend(Tox *tox, uint8_t *address, uint8_t *data, uint16_t length); |
90 | 111 | ||
91 | 112 | ||
92 | /* add a friend without sending a friendrequest. | 113 | /* add a friend without sending a friendrequest. |
93 | returns the friend number if success | 114 | returns the friend number if success |
94 | return -1 if failure. */ | 115 | return -1 if failure. */ |
95 | int tox_addfriend_norequest(void *tox, uint8_t *client_id); | 116 | int tox_addfriend_norequest(Tox *tox, uint8_t *client_id); |
96 | 117 | ||
97 | /* return the friend id associated to that client id. | 118 | /* return the friend id associated to that client id. |
98 | return -1 if no such friend */ | 119 | return -1 if no such friend */ |
99 | int tox_getfriend_id(void *tox, uint8_t *client_id); | 120 | int tox_getfriend_id(Tox *tox, uint8_t *client_id); |
100 | 121 | ||
101 | /* copies the public key associated to that friend id into client_id buffer. | 122 | /* copies the public key associated to that friend id into client_id buffer. |
102 | make sure that client_id is of size CLIENT_ID_SIZE. | 123 | make sure that client_id is of size CLIENT_ID_SIZE. |
103 | return 0 if success | 124 | return 0 if success |
104 | return -1 if failure */ | 125 | return -1 if failure */ |
105 | int tox_getclient_id(void *tox, int friend_id, uint8_t *client_id); | 126 | int tox_getclient_id(Tox *tox, int friend_id, uint8_t *client_id); |
106 | 127 | ||
107 | /* remove a friend */ | 128 | /* remove a friend */ |
108 | int tox_delfriend(void *tox, int friendnumber); | 129 | int tox_delfriend(Tox *tox, int friendnumber); |
109 | 130 | ||
110 | /* return 4 if friend is online | 131 | /* return 4 if friend is online |
111 | return 3 if friend is confirmed | 132 | return 3 if friend is confirmed |
112 | return 2 if the friend request was sent | 133 | return 2 if the friend request was sent |
113 | return 1 if the friend was added | 134 | return 1 if the friend was added |
114 | return 0 if there is no friend with that number */ | 135 | return 0 if there is no friend with that number */ |
115 | int tox_friendstatus(void *tox, int friendnumber); | 136 | int tox_friendstatus(Tox *tox, int friendnumber); |
116 | 137 | ||
117 | /* send a text chat message to an online friend | 138 | /* send a text chat message to an online friend |
118 | returns the message id if packet was successfully put into the send queue | 139 | returns the message id if packet was successfully put into the send queue |
@@ -121,13 +142,13 @@ int tox_friendstatus(void *tox, int friendnumber); | |||
121 | if one is received. | 142 | if one is received. |
122 | m_sendmessage_withid will send a message with the id of your choosing, | 143 | m_sendmessage_withid will send a message with the id of your choosing, |
123 | however we can generate an id for you by calling plain m_sendmessage. */ | 144 | however we can generate an id for you by calling plain m_sendmessage. */ |
124 | uint32_t tox_sendmessage(void *tox, int friendnumber, uint8_t *message, uint32_t length); | 145 | uint32_t tox_sendmessage(Tox *tox, int friendnumber, uint8_t *message, uint32_t length); |
125 | uint32_t tox_sendmessage_withid(void *tox, int friendnumber, uint32_t theid, uint8_t *message, uint32_t length); | 146 | uint32_t tox_sendmessage_withid(Tox *tox, int friendnumber, uint32_t theid, uint8_t *message, uint32_t length); |
126 | 147 | ||
127 | /* send an action to an online friend | 148 | /* send an action to an online friend |
128 | returns 1 if packet was successfully put into the send queue | 149 | returns 1 if packet was successfully put into the send queue |
129 | return 0 if it was not */ | 150 | return 0 if it was not */ |
130 | int tox_sendaction(void *tox, int friendnumber, uint8_t *action, uint32_t length); | 151 | int tox_sendaction(Tox *tox, int friendnumber, uint8_t *action, uint32_t length); |
131 | 152 | ||
132 | /* Set our nickname | 153 | /* Set our nickname |
133 | name must be a string of maximum MAX_NAME_LENGTH length. | 154 | name must be a string of maximum MAX_NAME_LENGTH length. |
@@ -135,7 +156,7 @@ int tox_sendaction(void *tox, int friendnumber, uint8_t *action, uint32_t length | |||
135 | length is the length of name with the NULL terminator | 156 | length is the length of name with the NULL terminator |
136 | return 0 if success | 157 | return 0 if success |
137 | return -1 if failure */ | 158 | return -1 if failure */ |
138 | int tox_setname(void *tox, uint8_t *name, uint16_t length); | 159 | int tox_setname(Tox *tox, uint8_t *name, uint16_t length); |
139 | 160 | ||
140 | /* | 161 | /* |
141 | Get your nickname. | 162 | Get your nickname. |
@@ -144,71 +165,71 @@ int tox_setname(void *tox, uint8_t *name, uint16_t length); | |||
144 | nlen The length of the string buffer. | 165 | nlen The length of the string buffer. |
145 | returns Return the length of the name, 0 on error. | 166 | returns Return the length of the name, 0 on error. |
146 | */ | 167 | */ |
147 | uint16_t tox_getselfname(void *tox, uint8_t *name, uint16_t nlen); | 168 | uint16_t tox_getselfname(Tox *tox, uint8_t *name, uint16_t nlen); |
148 | 169 | ||
149 | /* get name of friendnumber | 170 | /* get name of friendnumber |
150 | put it in name | 171 | put it in name |
151 | name needs to be a valid memory location with a size of at least MAX_NAME_LENGTH (128) bytes. | 172 | name needs to be a valid memory location with a size of at least MAX_NAME_LENGTH (128) bytes. |
152 | return 0 if success | 173 | return 0 if success |
153 | return -1 if failure */ | 174 | return -1 if failure */ |
154 | int tox_getname(void *tox, int friendnumber, uint8_t *name); | 175 | int tox_getname(Tox *tox, int friendnumber, uint8_t *name); |
155 | 176 | ||
156 | /* set our user status | 177 | /* set our user status |
157 | you are responsible for freeing status after | 178 | you are responsible for freeing status after |
158 | returns 0 on success, -1 on failure */ | 179 | returns 0 on success, -1 on failure */ |
159 | int tox_set_statusmessage(void *tox, uint8_t *status, uint16_t length); | 180 | int tox_set_statusmessage(Tox *tox, uint8_t *status, uint16_t length); |
160 | int tox_set_userstatus(void *tox, USERSTATUS status); | 181 | int tox_set_userstatus(Tox *tox, TOX_USERSTATUS status); |
161 | 182 | ||
162 | /* return the length of friendnumber's status message, | 183 | /* return the length of friendnumber's status message, |
163 | including null | 184 | including null |
164 | pass it into malloc */ | 185 | pass it into malloc */ |
165 | int tox_get_statusmessage_size(void *tox, int friendnumber); | 186 | int tox_get_statusmessage_size(Tox *tox, int friendnumber); |
166 | 187 | ||
167 | /* copy friendnumber's status message into buf, truncating if size is over maxlen | 188 | /* copy friendnumber's status message into buf, truncating if size is over maxlen |
168 | get the size you need to allocate from m_get_statusmessage_size | 189 | get the size you need to allocate from m_get_statusmessage_size |
169 | The self variant will copy our own status message. */ | 190 | The self variant will copy our own status message. */ |
170 | int tox_copy_statusmessage(void *tox, int friendnumber, uint8_t *buf, uint32_t maxlen); | 191 | int tox_copy_statusmessage(Tox *tox, int friendnumber, uint8_t *buf, uint32_t maxlen); |
171 | int tox_copy_self_statusmessage(void *tox, uint8_t *buf, uint32_t maxlen); | 192 | int tox_copy_self_statusmessage(Tox *tox, uint8_t *buf, uint32_t maxlen); |
172 | 193 | ||
173 | /* Return one of USERSTATUS values. | 194 | /* Return one of USERSTATUS values. |
174 | * Values unknown to your application should be represented as USERSTATUS_NONE. | 195 | * Values unknown to your application should be represented as USERSTATUS_NONE. |
175 | * As above, the self variant will return our own USERSTATUS. | 196 | * As above, the self variant will return our own USERSTATUS. |
176 | * If friendnumber is invalid, this shall return USERSTATUS_INVALID. */ | 197 | * If friendnumber is invalid, this shall return USERSTATUS_INVALID. */ |
177 | TOX_USERSTATUS tox_get_userstatus(void *tox, int friendnumber); | 198 | TOX_USERSTATUS tox_get_userstatus(Tox *tox, int friendnumber); |
178 | TOX_USERSTATUS tox_get_selfuserstatus(void *tox); | 199 | TOX_USERSTATUS tox_get_selfuserstatus(Tox *tox); |
179 | 200 | ||
180 | /* Sets whether we send read receipts for friendnumber. | 201 | /* Sets whether we send read receipts for friendnumber. |
181 | * This function is not lazy, and it will fail if yesno is not (0 or 1).*/ | 202 | * This function is not lazy, and it will fail if yesno is not (0 or 1).*/ |
182 | void tox_set_sends_receipts(void *tox, int friendnumber, int yesno); | 203 | void tox_set_sends_receipts(Tox *tox, int friendnumber, int yesno); |
183 | 204 | ||
184 | /* set the function that will be executed when a friend request is received. | 205 | /* set the function that will be executed when a friend request is received. |
185 | function format is function(uint8_t * public_key, uint8_t * data, uint16_t length) */ | 206 | function format is function(uint8_t * public_key, uint8_t * data, uint16_t length) */ |
186 | void tox_callback_friendrequest(void *tox, void (*function)(uint8_t *, uint8_t *, uint16_t, void *), void *userdata); | 207 | void tox_callback_friendrequest(Tox *tox, void (*function)(uint8_t *, uint8_t *, uint16_t, void *), void *userdata); |
187 | 208 | ||
188 | /* set the function that will be executed when a message from a friend is received. | 209 | /* set the function that will be executed when a message from a friend is received. |
189 | function format is: function(int friendnumber, uint8_t * message, uint32_t length) */ | 210 | function format is: function(int friendnumber, uint8_t * message, uint32_t length) */ |
190 | void tox_callback_friendmessage(void *tox, void (*function)(void *tox, int, uint8_t *, uint16_t, void *), | 211 | void tox_callback_friendmessage(Tox *tox, void (*function)(Tox *tox, int, uint8_t *, uint16_t, void *), |
191 | void *userdata); | 212 | void *userdata); |
192 | 213 | ||
193 | /* set the function that will be executed when an action from a friend is received. | 214 | /* set the function that will be executed when an action from a friend is received. |
194 | function format is: function(int friendnumber, uint8_t * action, uint32_t length) */ | 215 | function format is: function(int friendnumber, uint8_t * action, uint32_t length) */ |
195 | void tox_callback_action(void *tox, void (*function)(void *tox, int, uint8_t *, uint16_t, void *), void *userdata); | 216 | void tox_callback_action(Tox *tox, void (*function)(Tox *tox, int, uint8_t *, uint16_t, void *), void *userdata); |
196 | 217 | ||
197 | /* set the callback for name changes | 218 | /* set the callback for name changes |
198 | function(int friendnumber, uint8_t *newname, uint16_t length) | 219 | function(int friendnumber, uint8_t *newname, uint16_t length) |
199 | you are not responsible for freeing newname */ | 220 | you are not responsible for freeing newname */ |
200 | void tox_callback_namechange(void *tox, void (*function)(void *tox, int, uint8_t *, uint16_t, void *), | 221 | void tox_callback_namechange(Tox *tox, void (*function)(Tox *tox, int, uint8_t *, uint16_t, void *), |
201 | void *userdata); | 222 | void *userdata); |
202 | 223 | ||
203 | /* set the callback for status message changes | 224 | /* set the callback for status message changes |
204 | function(int friendnumber, uint8_t *newstatus, uint16_t length) | 225 | function(int friendnumber, uint8_t *newstatus, uint16_t length) |
205 | you are not responsible for freeing newstatus */ | 226 | you are not responsible for freeing newstatus */ |
206 | void tox_callback_statusmessage(void *tox, void (*function)(void *tox, int, uint8_t *, uint16_t, void *), | 227 | void tox_callback_statusmessage(Tox *tox, void (*function)(Tox *tox, int, uint8_t *, uint16_t, void *), |
207 | void *userdata); | 228 | void *userdata); |
208 | 229 | ||
209 | /* set the callback for status type changes | 230 | /* set the callback for status type changes |
210 | function(int friendnumber, USERSTATUS kind) */ | 231 | function(int friendnumber, USERSTATUS kind) */ |
211 | void tox_callback_userstatus(void *tox, void (*function)(void *tox, int, USERSTATUS, void *), void *userdata); | 232 | void tox_callback_userstatus(Tox *tox, void (*function)(Tox *tox, int, TOX_USERSTATUS, void *), void *userdata); |
212 | 233 | ||
213 | /* set the callback for read receipts | 234 | /* set the callback for read receipts |
214 | function(int friendnumber, uint32_t receipt) | 235 | function(int friendnumber, uint32_t receipt) |
@@ -217,7 +238,7 @@ void tox_callback_userstatus(void *tox, void (*function)(void *tox, int, USERSTA | |||
217 | has been received on the other side. since core doesn't | 238 | has been received on the other side. since core doesn't |
218 | track ids for you, receipt may not correspond to any message | 239 | track ids for you, receipt may not correspond to any message |
219 | in that case, you should discard it. */ | 240 | in that case, you should discard it. */ |
220 | void tox_callback_read_receipt(void *tox, void (*function)(void *tox, int, uint32_t, void *), void *userdata); | 241 | void tox_callback_read_receipt(Tox *tox, void (*function)(Tox *tox, int, uint32_t, void *), void *userdata); |
221 | 242 | ||
222 | /* set the callback for connection status changes | 243 | /* set the callback for connection status changes |
223 | function(int friendnumber, uint8_t status) | 244 | function(int friendnumber, uint8_t status) |
@@ -227,38 +248,39 @@ void tox_callback_read_receipt(void *tox, void (*function)(void *tox, int, uint3 | |||
227 | note that this callback is not called when adding friends, thus the "after | 248 | note that this callback is not called when adding friends, thus the "after |
228 | being previously online" part. it's assumed that when adding friends, | 249 | being previously online" part. it's assumed that when adding friends, |
229 | their connection status is offline. */ | 250 | their connection status is offline. */ |
230 | void tox_callback_connectionstatus(void *tox, void (*function)(void *tox, int, uint8_t, void *), void *userdata); | 251 | void tox_callback_connectionstatus(Tox *tox, void (*function)(Tox *tox, int, uint8_t, void *), void *userdata); |
231 | 252 | ||
232 | /* Use this function to bootstrap the client | 253 | /* Use this function to bootstrap the client |
233 | Sends a get nodes request to the given node with ip port and public_key */ | 254 | Sends a get nodes request to the given node with ip port and public_key */ |
234 | void tox_bootstrap(void *tox, IP_Port ip_port, uint8_t *public_key); | 255 | void tox_bootstrap(Tox *tox, IP_Port ip_port, uint8_t *public_key); |
235 | 256 | ||
236 | /* returns 0 if we are not connected to the DHT | 257 | /* returns 0 if we are not connected to the DHT |
237 | returns 1 if we are */ | 258 | returns 1 if we are */ |
238 | int tox_isconnected(void *tox); | 259 | int tox_isconnected(Tox *tox); |
239 | 260 | ||
240 | /* run this at startup | 261 | /* run this at startup |
241 | * returns allocated instance of tox on success | 262 | * returns allocated instance of tox on success |
242 | * returns 0 if there are problems */ | 263 | * returns 0 if there are problems */ |
243 | void *tox_new(void); | 264 | Tox *tox_new(void); |
244 | 265 | ||
245 | /* run this before closing shop | 266 | /* run this before closing shop |
246 | * free all datastructures */ | 267 | * free all datastructures */ |
247 | void tox_kill(void *tox); | 268 | void tox_kill(Tox *tox); |
248 | 269 | ||
249 | /* the main loop that needs to be run at least 20 times per second */ | 270 | /* the main loop that needs to be run at least 20 times per second */ |
250 | void tox_do(void *tox); | 271 | void tox_do(Tox *tox); |
251 | 272 | ||
252 | /* SAVING AND LOADING FUNCTIONS: */ | 273 | /* SAVING AND LOADING FUNCTIONS: */ |
253 | 274 | ||
254 | /* returns the size of the messenger data (for saving) */ | 275 | /* returns the size of the messenger data (for saving) */ |
255 | uint32_t tox_size(void *tox); | 276 | uint32_t tox_size(Tox *tox); |
256 | 277 | ||
257 | /* save the messenger in data (must be allocated memory of size Messenger_size()) */ | 278 | /* save the messenger in data (must be allocated memory of size Messenger_size()) */ |
258 | void tox_save(void *tox, uint8_t *data); | 279 | void tox_save(Tox *tox, uint8_t *data); |
259 | 280 | ||
260 | /* load the messenger from data of size length */ | 281 | /* load the messenger from data of size length */ |
261 | int tox_load(void *tox, uint8_t *data, uint32_t length); | 282 | int tox_load(Tox *tox, uint8_t *data, uint32_t length); |
283 | |||
262 | 284 | ||
263 | #ifdef __cplusplus | 285 | #ifdef __cplusplus |
264 | } | 286 | } |
diff --git a/other/bootstrap_serverdaemon/DHT_bootstrap_daemon.c b/other/bootstrap_serverdaemon/DHT_bootstrap_daemon.c index 7604b1e0..46409b76 100644 --- a/other/bootstrap_serverdaemon/DHT_bootstrap_daemon.c +++ b/other/bootstrap_serverdaemon/DHT_bootstrap_daemon.c | |||
@@ -72,6 +72,47 @@ int b16_to_key(char b16_string[], uint8_t *bs_pubkey) | |||
72 | return 0; | 72 | return 0; |
73 | } | 73 | } |
74 | 74 | ||
75 | /* | ||
76 | resolve_addr(): | ||
77 | address should represent IPv4 or a hostname with A record | ||
78 | |||
79 | returns a data in network byte order that can be used to set IP.i or IP_Port.ip.i | ||
80 | returns 0 on failure | ||
81 | |||
82 | TODO: Fix ipv6 support | ||
83 | */ | ||
84 | |||
85 | uint32_t resolve_addr(const char *address) | ||
86 | { | ||
87 | struct addrinfo *server = NULL; | ||
88 | struct addrinfo hints; | ||
89 | int rc; | ||
90 | uint32_t addr; | ||
91 | |||
92 | memset(&hints, 0, sizeof(hints)); | ||
93 | hints.ai_family = AF_INET; // IPv4 only right now. | ||
94 | hints.ai_socktype = SOCK_DGRAM; // type of socket Tox uses. | ||
95 | |||
96 | rc = getaddrinfo(address, "echo", &hints, &server); | ||
97 | |||
98 | // Lookup failed. | ||
99 | if (rc != 0) { | ||
100 | return 0; | ||
101 | } | ||
102 | |||
103 | // IPv4 records only.. | ||
104 | if (server->ai_family != AF_INET) { | ||
105 | freeaddrinfo(server); | ||
106 | return 0; | ||
107 | } | ||
108 | |||
109 | |||
110 | addr = ((struct sockaddr_in *)server->ai_addr)->sin_addr.s_addr; | ||
111 | |||
112 | freeaddrinfo(server); | ||
113 | return addr; | ||
114 | } | ||
115 | |||
75 | /* This unction connects to all specified servers | 116 | /* This unction connects to all specified servers |
76 | and connect to them. | 117 | and connect to them. |
77 | returns 1 if the connection to the DHT is up | 118 | returns 1 if the connection to the DHT is up |
diff --git a/testing/nTox.c b/testing/nTox.c index a476cc19..87fec818 100644 --- a/testing/nTox.c +++ b/testing/nTox.c | |||
@@ -43,22 +43,22 @@ char *help = "[i] commands:\n/f ID (to add friend)\n/m friendnumber message " | |||
43 | int x, y; | 43 | int x, y; |
44 | 44 | ||
45 | typedef struct { | 45 | typedef struct { |
46 | uint8_t id[CLIENT_ID_SIZE]; | 46 | uint8_t id[TOX_CLIENT_ID_SIZE]; |
47 | uint8_t accepted; | 47 | uint8_t accepted; |
48 | } Friend_request; | 48 | } Friend_request; |
49 | 49 | ||
50 | Friend_request pending_requests[256]; | 50 | Friend_request pending_requests[256]; |
51 | uint8_t num_requests = 0; | 51 | uint8_t num_requests = 0; |
52 | 52 | ||
53 | void get_id(Messenger *m, char *data) | 53 | void get_id(Tox *m, char *data) |
54 | { | 54 | { |
55 | sprintf(data, "[i] ID: "); | 55 | sprintf(data, "[i] ID: "); |
56 | int offset = strlen(data); | 56 | int offset = strlen(data); |
57 | int i = 0; | 57 | int i = 0; |
58 | uint8_t address[FRIEND_ADDRESS_SIZE]; | 58 | uint8_t address[TOX_FRIEND_ADDRESS_SIZE]; |
59 | getaddress(m, address); | 59 | tox_getaddress(m, address); |
60 | 60 | ||
61 | for (; i < FRIEND_ADDRESS_SIZE; i++) { | 61 | for (; i < TOX_FRIEND_ADDRESS_SIZE; i++) { |
62 | sprintf(data + 2 * i + offset, "%02X ", address[i]); | 62 | sprintf(data + 2 * i + offset, "%02X ", address[i]); |
63 | } | 63 | } |
64 | } | 64 | } |
@@ -75,15 +75,15 @@ void new_lines(char *line) | |||
75 | } | 75 | } |
76 | 76 | ||
77 | 77 | ||
78 | void print_friendlist(Messenger *m) | 78 | void print_friendlist(Tox *m) |
79 | { | 79 | { |
80 | char name[MAX_NAME_LENGTH]; | 80 | char name[TOX_MAX_NAME_LENGTH]; |
81 | int i = 0; | 81 | int i = 0; |
82 | new_lines("[i] Friend List:"); | 82 | new_lines("[i] Friend List:"); |
83 | 83 | ||
84 | while (getname(m, i, (uint8_t *)name) != -1) { | 84 | while (tox_getname(m, i, (uint8_t *)name) != -1) { |
85 | /* account for the longest name and the longest "base" string */ | 85 | /* account for the longest name and the longest "base" string */ |
86 | char fstring[MAX_NAME_LENGTH + strlen("[i] Friend: NULL\n\tid: ")]; | 86 | char fstring[TOX_MAX_NAME_LENGTH + strlen("[i] Friend: NULL\n\tid: ")]; |
87 | 87 | ||
88 | if (strlen(name) <= 0) { | 88 | if (strlen(name) <= 0) { |
89 | sprintf(fstring, "[i] Friend: No Friend!\n\tid: %i", i); | 89 | sprintf(fstring, "[i] Friend: No Friend!\n\tid: %i", i); |
@@ -99,14 +99,14 @@ void print_friendlist(Messenger *m) | |||
99 | new_lines("\tno friends! D:"); | 99 | new_lines("\tno friends! D:"); |
100 | } | 100 | } |
101 | 101 | ||
102 | char *format_message(Messenger *m, char *message, int friendnum) | 102 | char *format_message(Tox *m, char *message, int friendnum) |
103 | { | 103 | { |
104 | char name[MAX_NAME_LENGTH]; | 104 | char name[TOX_MAX_NAME_LENGTH]; |
105 | 105 | ||
106 | if (friendnum != -1) { | 106 | if (friendnum != -1) { |
107 | getname(m, friendnum, (uint8_t *)name); | 107 | tox_getname(m, friendnum, (uint8_t *)name); |
108 | } else { | 108 | } else { |
109 | getself_name(m, (uint8_t *)name, sizeof(name)); | 109 | tox_getselfname(m, (uint8_t *)name, sizeof(name)); |
110 | } | 110 | } |
111 | 111 | ||
112 | char *msg = malloc(100 + strlen(message) + strlen(name) + 1); | 112 | char *msg = malloc(100 + strlen(message) + strlen(name) + 1); |
@@ -129,7 +129,7 @@ char *format_message(Messenger *m, char *message, int friendnum) | |||
129 | return msg; | 129 | return msg; |
130 | } | 130 | } |
131 | 131 | ||
132 | void line_eval(Messenger *m, char *line) | 132 | void line_eval(Tox *m, char *line) |
133 | { | 133 | { |
134 | if (line[0] == '/') { | 134 | if (line[0] == '/') { |
135 | char inpt_command = line[1]; | 135 | char inpt_command = line[1]; |
@@ -146,28 +146,28 @@ void line_eval(Messenger *m, char *line) | |||
146 | temp_id[i] = line[i + prompt_offset]; | 146 | temp_id[i] = line[i + prompt_offset]; |
147 | 147 | ||
148 | unsigned char *bin_string = hex_string_to_bin(temp_id); | 148 | unsigned char *bin_string = hex_string_to_bin(temp_id); |
149 | int num = m_addfriend(m, bin_string, (uint8_t *)"Install Gentoo", sizeof("Install Gentoo")); | 149 | int num = tox_addfriend(m, bin_string, (uint8_t *)"Install Gentoo", sizeof("Install Gentoo")); |
150 | free(bin_string); | 150 | free(bin_string); |
151 | char numstring[100]; | 151 | char numstring[100]; |
152 | 152 | ||
153 | switch (num) { | 153 | switch (num) { |
154 | case FAERR_TOOLONG: | 154 | case TOX_FAERR_TOOLONG: |
155 | sprintf(numstring, "[i] Message is too long."); | 155 | sprintf(numstring, "[i] Message is too long."); |
156 | break; | 156 | break; |
157 | 157 | ||
158 | case FAERR_NOMESSAGE: | 158 | case TOX_FAERR_NOMESSAGE: |
159 | sprintf(numstring, "[i] Please add a message to your request."); | 159 | sprintf(numstring, "[i] Please add a message to your request."); |
160 | break; | 160 | break; |
161 | 161 | ||
162 | case FAERR_OWNKEY: | 162 | case TOX_FAERR_OWNKEY: |
163 | sprintf(numstring, "[i] That appears to be your own ID."); | 163 | sprintf(numstring, "[i] That appears to be your own ID."); |
164 | break; | 164 | break; |
165 | 165 | ||
166 | case FAERR_ALREADYSENT: | 166 | case TOX_FAERR_ALREADYSENT: |
167 | sprintf(numstring, "[i] Friend request already sent."); | 167 | sprintf(numstring, "[i] Friend request already sent."); |
168 | break; | 168 | break; |
169 | 169 | ||
170 | case FAERR_UNKNOWN: | 170 | case TOX_FAERR_UNKNOWN: |
171 | sprintf(numstring, "[i] Undefined error when adding friend."); | 171 | sprintf(numstring, "[i] Undefined error when adding friend."); |
172 | break; | 172 | break; |
173 | 173 | ||
@@ -179,7 +179,7 @@ void line_eval(Messenger *m, char *line) | |||
179 | new_lines(numstring); | 179 | new_lines(numstring); |
180 | do_refresh(); | 180 | do_refresh(); |
181 | } else if (inpt_command == 'd') { | 181 | } else if (inpt_command == 'd') { |
182 | doMessenger(m); | 182 | tox_do(m); |
183 | } else if (inpt_command == 'm') { //message command: /m friendnumber messsage | 183 | } else if (inpt_command == 'm') { //message command: /m friendnumber messsage |
184 | size_t len = strlen(line); | 184 | size_t len = strlen(line); |
185 | 185 | ||
@@ -205,13 +205,13 @@ void line_eval(Messenger *m, char *line) | |||
205 | 205 | ||
206 | int num = atoi(numstring); | 206 | int num = atoi(numstring); |
207 | 207 | ||
208 | if (m_sendmessage(m, num, (uint8_t *) message, strlen(message) + 1) != 1) { | 208 | if (tox_sendmessage(m, num, (uint8_t *) message, strlen(message) + 1) != 1) { |
209 | new_lines("[i] could not send message"); | 209 | new_lines("[i] could not send message"); |
210 | } else { | 210 | } else { |
211 | new_lines(format_message(m, message, -1)); | 211 | new_lines(format_message(m, message, -1)); |
212 | } | 212 | } |
213 | } else if (inpt_command == 'n') { | 213 | } else if (inpt_command == 'n') { |
214 | uint8_t name[MAX_NAME_LENGTH]; | 214 | uint8_t name[TOX_MAX_NAME_LENGTH]; |
215 | int i = 0; | 215 | int i = 0; |
216 | size_t len = strlen(line); | 216 | size_t len = strlen(line); |
217 | 217 | ||
@@ -222,14 +222,14 @@ void line_eval(Messenger *m, char *line) | |||
222 | } | 222 | } |
223 | 223 | ||
224 | name[i - 3] = 0; | 224 | name[i - 3] = 0; |
225 | setname(m, name, i - 2); | 225 | tox_setname(m, name, i - 2); |
226 | char numstring[100]; | 226 | char numstring[100]; |
227 | sprintf(numstring, "[i] changed nick to %s", (char *)name); | 227 | sprintf(numstring, "[i] changed nick to %s", (char *)name); |
228 | new_lines(numstring); | 228 | new_lines(numstring); |
229 | } else if (inpt_command == 'l') { | 229 | } else if (inpt_command == 'l') { |
230 | print_friendlist(m); | 230 | print_friendlist(m); |
231 | } else if (inpt_command == 's') { | 231 | } else if (inpt_command == 's') { |
232 | uint8_t status[MAX_STATUSMESSAGE_LENGTH]; | 232 | uint8_t status[TOX_MAX_STATUSMESSAGE_LENGTH]; |
233 | int i = 0; | 233 | int i = 0; |
234 | size_t len = strlen(line); | 234 | size_t len = strlen(line); |
235 | 235 | ||
@@ -240,7 +240,7 @@ void line_eval(Messenger *m, char *line) | |||
240 | } | 240 | } |
241 | 241 | ||
242 | status[i - 3] = 0; | 242 | status[i - 3] = 0; |
243 | m_set_statusmessage(m, status, strlen((char *)status) + 1); | 243 | tox_set_statusmessage(m, status, strlen((char *)status) + 1); |
244 | char numstring[100]; | 244 | char numstring[100]; |
245 | sprintf(numstring, "[i] changed status to %s", (char *)status); | 245 | sprintf(numstring, "[i] changed status to %s", (char *)status); |
246 | new_lines(numstring); | 246 | new_lines(numstring); |
@@ -252,7 +252,7 @@ void line_eval(Messenger *m, char *line) | |||
252 | sprintf(numchar, "[i] you either didn't receive that request or you already accepted it"); | 252 | sprintf(numchar, "[i] you either didn't receive that request or you already accepted it"); |
253 | new_lines(numchar); | 253 | new_lines(numchar); |
254 | } else { | 254 | } else { |
255 | int num = m_addfriend_norequest(m, pending_requests[numf].id); | 255 | int num = tox_addfriend_norequest(m, pending_requests[numf].id); |
256 | 256 | ||
257 | if (num != -1) { | 257 | if (num != -1) { |
258 | pending_requests[numf].accepted = 1; | 258 | pending_requests[numf].accepted = 1; |
@@ -364,40 +364,40 @@ void print_request(uint8_t *public_key, uint8_t *data, uint16_t length, void *us | |||
364 | char numchar[100]; | 364 | char numchar[100]; |
365 | sprintf(numchar, "[i] accept request with /a %u", num_requests); | 365 | sprintf(numchar, "[i] accept request with /a %u", num_requests); |
366 | new_lines(numchar); | 366 | new_lines(numchar); |
367 | memcpy(pending_requests[num_requests].id, public_key, CLIENT_ID_SIZE); | 367 | memcpy(pending_requests[num_requests].id, public_key, TOX_CLIENT_ID_SIZE); |
368 | pending_requests[num_requests].accepted = 0; | 368 | pending_requests[num_requests].accepted = 0; |
369 | ++num_requests; | 369 | ++num_requests; |
370 | do_refresh(); | 370 | do_refresh(); |
371 | } | 371 | } |
372 | 372 | ||
373 | void print_message(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void *userdata) | 373 | void print_message(Tox *m, int friendnumber, uint8_t *string, uint16_t length, void *userdata) |
374 | { | 374 | { |
375 | new_lines(format_message(m, (char *)string, friendnumber)); | 375 | new_lines(format_message(m, (char *)string, friendnumber)); |
376 | } | 376 | } |
377 | 377 | ||
378 | void print_nickchange(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void *userdata) | 378 | void print_nickchange(Tox *m, int friendnumber, uint8_t *string, uint16_t length, void *userdata) |
379 | { | 379 | { |
380 | char name[MAX_NAME_LENGTH]; | 380 | char name[TOX_MAX_NAME_LENGTH]; |
381 | 381 | ||
382 | if (getname(m, friendnumber, (uint8_t *)name) != -1) { | 382 | if (tox_getname(m, friendnumber, (uint8_t *)name) != -1) { |
383 | char msg[100 + length]; | 383 | char msg[100 + length]; |
384 | sprintf(msg, "[i] [%d] %s is now known as %s.", friendnumber, name, string); | 384 | sprintf(msg, "[i] [%d] %s is now known as %s.", friendnumber, name, string); |
385 | new_lines(msg); | 385 | new_lines(msg); |
386 | } | 386 | } |
387 | } | 387 | } |
388 | 388 | ||
389 | void print_statuschange(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void *userdata) | 389 | void print_statuschange(Tox *m, int friendnumber, uint8_t *string, uint16_t length, void *userdata) |
390 | { | 390 | { |
391 | char name[MAX_NAME_LENGTH]; | 391 | char name[TOX_MAX_NAME_LENGTH]; |
392 | 392 | ||
393 | if (getname(m, friendnumber, (uint8_t *)name) != -1) { | 393 | if (tox_getname(m, friendnumber, (uint8_t *)name) != -1) { |
394 | char msg[100 + length + strlen(name) + 1]; | 394 | char msg[100 + length + strlen(name) + 1]; |
395 | sprintf(msg, "[i] [%d] %s's status changed to %s.", friendnumber, name, string); | 395 | sprintf(msg, "[i] [%d] %s's status changed to %s.", friendnumber, name, string); |
396 | new_lines(msg); | 396 | new_lines(msg); |
397 | } | 397 | } |
398 | } | 398 | } |
399 | 399 | ||
400 | void load_key(Messenger *m, char *path) | 400 | void load_key(Tox *m, char *path) |
401 | { | 401 | { |
402 | FILE *data_file = fopen(path, "r"); | 402 | FILE *data_file = fopen(path, "r"); |
403 | int size = 0; | 403 | int size = 0; |
@@ -415,13 +415,13 @@ void load_key(Messenger *m, char *path) | |||
415 | goto FILE_ERROR; | 415 | goto FILE_ERROR; |
416 | } | 416 | } |
417 | 417 | ||
418 | Messenger_load(m, data, size); | 418 | tox_load(m, data, size); |
419 | 419 | ||
420 | } else { | 420 | } else { |
421 | //else save new keys | 421 | //else save new keys |
422 | int size = Messenger_size(m); | 422 | int size = tox_size(m); |
423 | uint8_t data[size]; | 423 | uint8_t data[size]; |
424 | Messenger_save(m, data); | 424 | tox_save(m, data); |
425 | data_file = fopen(path, "w"); | 425 | data_file = fopen(path, "w"); |
426 | 426 | ||
427 | if (!data_file) { | 427 | if (!data_file) { |
@@ -463,7 +463,7 @@ int main(int argc, char *argv[]) | |||
463 | int i = 0; | 463 | int i = 0; |
464 | char *filename = "data"; | 464 | char *filename = "data"; |
465 | char idstring[200] = {0}; | 465 | char idstring[200] = {0}; |
466 | Messenger *m; | 466 | Tox *m; |
467 | 467 | ||
468 | if (argc < 4) { | 468 | if (argc < 4) { |
469 | printf("[!] Usage: %s [IP] [port] [public_key] <keyfile>\n", argv[0]); | 469 | printf("[!] Usage: %s [IP] [port] [public_key] <keyfile>\n", argv[0]); |
@@ -487,7 +487,7 @@ int main(int argc, char *argv[]) | |||
487 | } | 487 | } |
488 | } | 488 | } |
489 | 489 | ||
490 | m = initMessenger(); | 490 | m = tox_new(); |
491 | 491 | ||
492 | if ( !m ) { | 492 | if ( !m ) { |
493 | fputs("Failed to allocate Messenger datastructure", stderr); | 493 | fputs("Failed to allocate Messenger datastructure", stderr); |
@@ -496,10 +496,10 @@ int main(int argc, char *argv[]) | |||
496 | 496 | ||
497 | load_key(m, filename); | 497 | load_key(m, filename); |
498 | 498 | ||
499 | m_callback_friendrequest(m, print_request, NULL); | 499 | tox_callback_friendrequest(m, print_request, NULL); |
500 | m_callback_friendmessage(m, print_message, NULL); | 500 | tox_callback_friendmessage(m, print_message, NULL); |
501 | m_callback_namechange(m, print_nickchange, NULL); | 501 | tox_callback_namechange(m, print_nickchange, NULL); |
502 | m_callback_statusmessage(m, print_statuschange, NULL); | 502 | tox_callback_statusmessage(m, print_statuschange, NULL); |
503 | 503 | ||
504 | initscr(); | 504 | initscr(); |
505 | noecho(); | 505 | noecho(); |
@@ -521,17 +521,17 @@ int main(int argc, char *argv[]) | |||
521 | exit(1); | 521 | exit(1); |
522 | 522 | ||
523 | unsigned char *binary_string = hex_string_to_bin(argv[3]); | 523 | unsigned char *binary_string = hex_string_to_bin(argv[3]); |
524 | DHT_bootstrap(m->dht, bootstrap_ip_port, binary_string); | 524 | tox_bootstrap(m, bootstrap_ip_port, binary_string); |
525 | free(binary_string); | 525 | free(binary_string); |
526 | nodelay(stdscr, TRUE); | 526 | nodelay(stdscr, TRUE); |
527 | 527 | ||
528 | while (true) { | 528 | while (true) { |
529 | if (on == 0 && DHT_isconnected(m->dht)) { | 529 | if (on == 0 && tox_isconnected(m)) { |
530 | new_lines("[i] connected to DHT\n[i] define username with /n"); | 530 | new_lines("[i] connected to DHT\n[i] define username with /n"); |
531 | on = 1; | 531 | on = 1; |
532 | } | 532 | } |
533 | 533 | ||
534 | doMessenger(m); | 534 | tox_do(m); |
535 | c_sleep(1); | 535 | c_sleep(1); |
536 | do_refresh(); | 536 | do_refresh(); |
537 | 537 | ||
@@ -552,7 +552,7 @@ int main(int argc, char *argv[]) | |||
552 | } | 552 | } |
553 | } | 553 | } |
554 | 554 | ||
555 | cleanupMessenger(m); | 555 | tox_kill(m); |
556 | endwin(); | 556 | endwin(); |
557 | return 0; | 557 | return 0; |
558 | } | 558 | } |
diff --git a/testing/nTox.h b/testing/nTox.h index fdd88fb4..b27a956f 100644 --- a/testing/nTox.h +++ b/testing/nTox.h | |||
@@ -35,15 +35,55 @@ | |||
35 | #include <arpa/inet.h> | 35 | #include <arpa/inet.h> |
36 | #include <sys/types.h> | 36 | #include <sys/types.h> |
37 | #include <netdb.h> | 37 | #include <netdb.h> |
38 | #include "../core/Messenger.h" | 38 | #include "../core/tox.h" |
39 | #include "../core/network.h" | ||
40 | 39 | ||
41 | #define STRING_LENGTH 256 | 40 | #define STRING_LENGTH 256 |
42 | #define HISTORY 50 | 41 | #define HISTORY 50 |
43 | #define PUB_KEY_BYTES 32 | 42 | #define PUB_KEY_BYTES 32 |
44 | 43 | ||
44 | /* | ||
45 | resolve_addr(): | ||
46 | address should represent IPv4 or a hostname with A record | ||
47 | |||
48 | returns a data in network byte order that can be used to set IP.i or IP_Port.ip.i | ||
49 | returns 0 on failure | ||
50 | |||
51 | TODO: Fix ipv6 support | ||
52 | */ | ||
53 | |||
54 | uint32_t resolve_addr(const char *address) | ||
55 | { | ||
56 | struct addrinfo *server = NULL; | ||
57 | struct addrinfo hints; | ||
58 | int rc; | ||
59 | uint32_t addr; | ||
60 | |||
61 | memset(&hints, 0, sizeof(hints)); | ||
62 | hints.ai_family = AF_INET; // IPv4 only right now. | ||
63 | hints.ai_socktype = SOCK_DGRAM; // type of socket Tox uses. | ||
64 | |||
65 | rc = getaddrinfo(address, "echo", &hints, &server); | ||
66 | |||
67 | // Lookup failed. | ||
68 | if (rc != 0) { | ||
69 | return 0; | ||
70 | } | ||
71 | |||
72 | // IPv4 records only.. | ||
73 | if (server->ai_family != AF_INET) { | ||
74 | freeaddrinfo(server); | ||
75 | return 0; | ||
76 | } | ||
77 | |||
78 | |||
79 | addr = ((struct sockaddr_in *)server->ai_addr)->sin_addr.s_addr; | ||
80 | |||
81 | freeaddrinfo(server); | ||
82 | return addr; | ||
83 | } | ||
84 | |||
45 | void new_lines(char *line); | 85 | void new_lines(char *line); |
46 | void line_eval(Messenger *m, char *line); | 86 | void line_eval(Tox *m, char *line); |
47 | void wrap(char output[STRING_LENGTH], char input[STRING_LENGTH], int line_width) ; | 87 | void wrap(char output[STRING_LENGTH], char input[STRING_LENGTH], int line_width) ; |
48 | int count_lines(char *string) ; | 88 | int count_lines(char *string) ; |
49 | char *appender(char *str, const char c); | 89 | char *appender(char *str, const char c); |