1 #define _XOPEN_SOURCE 500
11 int main(int argc
, char **argv
) {
12 struct isds_ctx
*ctx
= NULL
;
14 char *last_message_id
= NULL
;
16 setlocale(LC_ALL
, "");
20 printf("isds_init() failed: %s\n", isds_strerror(err
));
24 isds_set_logging(ILF_ALL
& ~ILF_HTTP
, ILL_ALL
);
26 ctx
= isds_ctx_create();
28 printf("isds_ctx_create() failed");
31 err
= isds_set_timeout(ctx
, 10000);
33 printf("isds_set_timeout() failed: %s\n", isds_strerror(err
));
36 /* err = isds_set_tls(ctx, ITLS_VERIFY_SERVER, 0);
38 printf("isds_set_tls(ITLS_VERIFY_SERVER) failed: %s\n",
42 err = isds_set_tls(ctx, ITLS_CA_FILE, "/etc/ssl/certs/ca-certificates.crt");
44 printf("isds_set_tls(ITLS_CA_FILE) failed: %s\n",
48 err
= isds_login(ctx
, url
, username
, password
, NULL
, NULL
);
50 printf("isds_login() failed: %s: %s\n", isds_strerror(err
),
51 isds_long_message(ctx
));
53 printf("Logged in :)\n");
58 /* Get list of received messages */
60 struct tm from_time_tm
= {
61 .tm_year
= 2000 - 1900,
69 time_t from_time_t
= mktime(&from_time_tm
);
70 struct timeval from_time
= {
71 .tv_sec
= from_time_t
,
74 unsigned long int number
= 0;
75 struct isds_list
*messages
= NULL
, *item
;
76 struct isds_message
*last_message
= NULL
;
78 /* TODO: Try different criteria */
79 printf("Getting list of received messages\n");
80 err
= isds_get_list_of_received_messages(ctx
, &from_time
, NULL
, NULL
,
81 MESSAGESTATE_ANY
, 0, &number
, &messages
);
83 printf("isds_get_list_of_received_messages() failed: %s: %s\n",
84 isds_strerror(err
), isds_long_message(ctx
));
86 printf("isds_get_list_of_received_messages() succeeded: "
87 "number of messages = %lu:\n", number
);
88 for(item
= messages
; item
; item
= item
->next
) {
89 last_message
= (struct isds_message
*) (item
->data
);
95 /*Save last message for latter refference */
96 if (last_message
->envelope
&& last_message
->envelope
->dmID
) {
97 last_message_id
= strdup(last_message
->envelope
->dmID
);
101 isds_list_free(&messages
);
105 if (last_message_id
) {
106 /* Download last message */
107 struct isds_message
*message
= NULL
;
109 printf("Getting last received message with ID: %s\n", last_message_id
);
110 err
= isds_get_received_message(ctx
, last_message_id
, &message
);
112 printf("isds_get_received_message() failed: %s: %s\n",
113 isds_strerror(err
), isds_long_message(ctx
));
115 printf("isds_get_received_message() succeeded:\n");
116 print_message(message
);
120 /* Download last message hash */
121 struct isds_hash
*hash
= NULL
;
123 printf("Getting last received message hash with ID: %s\n",
125 err
= isds_download_message_hash(ctx
, last_message_id
, &hash
);
127 printf("isds_download_message_hash() failed: %s: %s\n",
128 isds_strerror(err
), isds_long_message(ctx
));
130 printf("isds_download_message_hash() succeeded: ");
134 /* Recompute last message hash locally */
135 printf("Recalculating last received message hash\n");
136 err
= isds_compute_message_hash(ctx
, message
, hash
->algorithm
);
138 printf("isds_compute_message_hash() failed: %s: %s\n",
139 isds_strerror(err
), isds_long_message(ctx
));
141 printf("isds_compute_message_hash() succeeded: ");
142 print_hash(message
->envelope
->hash
);
146 isds_hash_free(&hash
);
147 isds_message_free(&message
);
148 free(last_message_id
);
152 /* Download hash with invalid ID*/
154 struct isds_hash
*hash
= NULL
;
155 char *id
= "123456789112345678921";
157 printf("Getting message hash with invalid ID: %s\n", id
);
158 err
= isds_download_message_hash(ctx
, id
, &hash
);
160 printf("isds_download_message_hash() failed as assumed: %s: %s\n",
161 isds_strerror(err
), isds_long_message(ctx
));
163 printf("isds_download_message_hash() succeeded. "
164 "This should not happen: ");
168 isds_hash_free(&hash
);
172 /* Download nonexistent message hash */
174 struct isds_hash
*hash
= NULL
;
175 char *id
= "7777777";
177 printf("Getting nonexistent message hash with ID: %s\n", id
);
178 err
= isds_download_message_hash(ctx
, id
, &hash
);
180 printf("isds_download_message_hash() failed as assumed: %s: %s\n",
181 isds_strerror(err
), isds_long_message(ctx
));
183 printf("isds_download_message_hash() succeeded. "
184 "This should not happen: ");
188 isds_hash_free(&hash
);
192 err
= isds_logout(ctx
);
194 printf("isds_logout() failed: %s\n", isds_strerror(err
));
198 err
= isds_ctx_free(&ctx
);
200 printf("isds_ctx_free() failed: %s\n", isds_strerror(err
));
204 err
= isds_cleanup();
206 printf("isds_cleanup() failed: %s\n", isds_strerror(err
));