summaryrefslogtreecommitdiff
path: root/doc/examples/ex-client-x509-3.1.c
diff options
context:
space:
mode:
Diffstat (limited to 'doc/examples/ex-client-x509-3.1.c')
-rw-r--r--doc/examples/ex-client-x509-3.1.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/doc/examples/ex-client-x509-3.1.c b/doc/examples/ex-client-x509-3.1.c
index a6cc5241c0..bd7fd2fcb6 100644
--- a/doc/examples/ex-client-x509-3.1.c
+++ b/doc/examples/ex-client-x509-3.1.c
@@ -18,6 +18,11 @@
*/
#define CHECK(x) assert((x)>=0)
+#define LOOP_CHECK(rval, cmd) \
+ do { \
+ rval = cmd; \
+ } while(rval == GNUTLS_E_AGAIN || rval == GNUTLS_E_INTERRUPTED); \
+ assert(rval >= 0)
#define MAX_BUF 1024
#define CAFILE "/etc/ssl/certs/ca-certificates.crt"
@@ -62,10 +67,10 @@ int main(void)
*/
CHECK(gnutls_init(&session, GNUTLS_CLIENT));
- gnutls_session_set_ptr(session, (void *) "my_host_name");
+ gnutls_session_set_ptr(session, (void *) "www.example.com");
- gnutls_server_name_set(session, GNUTLS_NAME_DNS, "my_host_name",
- strlen("my_host_name"));
+ gnutls_server_name_set(session, GNUTLS_NAME_DNS, "www.example.com",
+ strlen("www.example.com"));
/* use default priorities */
CHECK(gnutls_set_default_priority(session));
@@ -112,9 +117,9 @@ int main(void)
gnutls_free(desc);
}
- CHECK(gnutls_record_send(session, MSG, strlen(MSG)));
+ LOOP_CHECK(ret, gnutls_record_send(session, MSG, strlen(MSG)));
- ret = gnutls_record_recv(session, buffer, MAX_BUF);
+ LOOP_CHECK(ret, gnutls_record_recv(session, buffer, MAX_BUF));
if (ret == 0) {
printf("- Peer has closed the TLS connection\n");
goto end;