2 #define _XOPEN_SOURCE XOPEN_SOURCE_LEVEL_FOR_STRDUP
13 struct isds_ctx
*ctx
= NULL
;
15 char *last_message_id
= NULL
;
17 setlocale(LC_ALL
, "");
21 printf("isds_init() failed: %s\n", isds_strerror(err
));
25 isds_set_logging(ILF_ALL
& ~ILF_HTTP
, ILL_ALL
);
27 ctx
= isds_ctx_create();
29 printf("isds_ctx_create() failed");
32 err
= isds_set_timeout(ctx
, 10000);
34 printf("isds_set_timeout() failed: %s\n", isds_strerror(err
));
37 err
= isds_login(ctx
, url
, username(), password(), NULL
, NULL
);
39 printf("isds_login() failed: %s: %s\n", isds_strerror(err
),
40 isds_long_message(ctx
));
42 printf("Logged in :)\n");
47 /* Get list of received messages */
49 struct tm from_time_tm
= {
50 .tm_year
= 2000 - 1900,
58 time_t from_time_t
= mktime(&from_time_tm
);
59 struct timeval from_time
= {
60 .tv_sec
= from_time_t
,
63 unsigned long int number
= 0;
64 struct isds_list
*messages
= NULL
, *item
;
65 struct isds_message
*last_message
= NULL
;
67 /* TODO: Try different criteria */
68 printf("Getting list of received messages\n");
69 err
= isds_get_list_of_received_messages(ctx
, &from_time
, NULL
, NULL
,
70 MESSAGESTATE_ANY
, 0, &number
, &messages
);
72 printf("isds_get_list_of_received_messages() failed: %s: %s\n",
73 isds_strerror(err
), isds_long_message(ctx
));
75 printf("isds_get_list_of_received_messages() succeeded: "
76 "number of messages = %lu:\n", number
);
77 for(item
= messages
; item
; item
= item
->next
) {
78 last_message
= (struct isds_message
*) (item
->data
);
84 /*Save last message for latter refference */
85 if (last_message
->envelope
&& last_message
->envelope
->dmID
) {
86 last_message_id
= strdup(last_message
->envelope
->dmID
);
90 isds_list_free(&messages
);
94 if (last_message_id
) {
95 /* Download last message */
96 struct isds_message
*message
= NULL
;
98 printf("Getting last received message with ID: %s\n", last_message_id
);
99 err
= isds_get_received_message(ctx
, last_message_id
, &message
);
101 printf("isds_get_received_message() failed: %s: %s\n",
102 isds_strerror(err
), isds_long_message(ctx
));
104 printf("isds_get_received_message() succeeded:\n");
105 print_message(message
);
109 /* Verify message hash */
110 printf("Verifying last received message hash against server\n");
111 err
= isds_verify_message_hash(ctx
, message
);
113 printf("isds_verify_message_hash() succeeded: "
114 "message is genuine\n");
115 printf("Computed hash: ");
116 print_hash(message
->envelope
->hash
);
117 } else if (err
== IE_NOTEQUAL
) {
118 printf("isds_verify_message_hash() failed: message is a fake\n");
119 printf("Computed hash: ");
120 print_hash(message
->envelope
->hash
);
121 printf("This should not happen\n");
123 printf("isds_verify_message_hash() failed: %s: %s\n",
124 isds_strerror(err
), isds_long_message(ctx
));
128 /* Download last signed message */
129 printf("Getting last signed received message with ID: %s\n",
131 err
= isds_get_signed_received_message(ctx
, last_message_id
, &message
);
133 printf("isds_get_signed_received_message() failed: %s: %s\n",
134 isds_strerror(err
), isds_long_message(ctx
));
136 printf("isds_get_signed_received_message() succeeded:\n");
137 printf("\tMessage should have the same content ;)\n");
140 /* Verify signed message hash */
141 printf("Verifying last signed received message hash against server\n");
142 err
= isds_verify_message_hash(ctx
, message
);
144 printf("isds_verify_message_hash() succeeded: "
145 "message is genuine\n");
146 printf("Computed hash: ");
147 print_hash(message
->envelope
->hash
);
148 } else if (err
== IE_NOTEQUAL
) {
149 printf("isds_verify_message_hash() failed: message is a fake\n");
150 printf("Computed hash: ");
151 print_hash(message
->envelope
->hash
);
152 printf("This should not happen\n");
154 printf("isds_verify_message_hash() failed: %s: %s\n",
155 isds_strerror(err
), isds_long_message(ctx
));
159 isds_message_free(&message
);
160 free(last_message_id
);
165 err
= isds_logout(ctx
);
167 printf("isds_logout() failed: %s\n", isds_strerror(err
));
171 err
= isds_ctx_free(&ctx
);
173 printf("isds_ctx_free() failed: %s\n", isds_strerror(err
));
177 err
= isds_cleanup();
179 printf("isds_cleanup() failed: %s\n", isds_strerror(err
));