blob: 426e4de999a60530f3badabd2821181a855e4fd9 [file] [log] [blame]
Richard Levitte28a08412016-02-02 15:54:57 +01001=pod
2
3=head1 NAME
4
Rich Salzd4ea9652017-03-11 12:48:32 -05005BIO_hostserv_priorities,
6BIO_parse_hostserv
7- utility routines to parse a standard host and service string
Richard Levitte28a08412016-02-02 15:54:57 +01008
9=head1 SYNOPSIS
10
11 #include <openssl/bio.h>
12
13 enum BIO_hostserv_priorities {
14 BIO_PARSE_PRIO_HOST, BIO_PARSE_PRIO_SERV
15 };
16 int BIO_parse_hostserv(const char *hostserv, char **host, char **service,
17 enum BIO_hostserv_priorities hostserv_prio);
18
19=head1 DESCRIPTION
20
21BIO_parse_hostserv() will parse the information given in B<hostserv>,
22create strings with the host name and service name and give those
23back via B<host> and B<service>. Those will need to be freed after
24they are used. B<hostserv_prio> helps determine if B<hostserv> shall
Alex Gaynorb9b6a7e2016-03-20 11:51:06 -040025be interpreted primarily as a host name or a service name in ambiguous
Richard Levitte28a08412016-02-02 15:54:57 +010026cases.
27
28The syntax the BIO_parse_hostserv() recognises is:
29
30 host + ':' + service
31 host + ':' + '*'
32 host + ':'
33 ':' + service
34 '*' + ':' + service
35 host
36 service
37
38The host part can be a name or an IP address. If it's a IPv6
39address, it MUST be enclosed in brackets, such as '[::1]'.
40
41The service part can be a service name or its port number.
42
43The returned values will depend on the given B<hostserv> string
44and B<hostserv_prio>, as follows:
45
Richard Levitte28a08412016-02-02 15:54:57 +010046 host + ':' + service => *host = "host", *service = "service"
47 host + ':' + '*' => *host = "host", *service = NULL
48 host + ':' => *host = "host", *service = NULL
49 ':' + service => *host = NULL, *service = "service"
50 '*' + ':' + service => *host = NULL, *service = "service"
Rich Salz1bc74512016-05-20 08:11:46 -040051
Richard Levitte28a08412016-02-02 15:54:57 +010052 in case no ':' is present in the string, the result depends on
53 hostserv_prio, as follows:
Rich Salz1bc74512016-05-20 08:11:46 -040054
Richard Levitte28a08412016-02-02 15:54:57 +010055 when hostserv_prio == BIO_PARSE_PRIO_HOST
56 host => *host = "host", *service untouched
Rich Salz1bc74512016-05-20 08:11:46 -040057
Richard Levitte28a08412016-02-02 15:54:57 +010058 when hostserv_prio == BIO_PARSE_PRIO_SERV
59 service => *host untouched, *service = "service"
60
61=head1 SEE ALSO
62
63L<BIO_ADDRINFO(3)>
Rich Salz99ec4fd2016-05-18 10:16:40 -040064
Rich Salze2f92612016-05-18 11:44:05 -040065=head1 COPYRIGHT
66
67Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
68
69Licensed under the OpenSSL license (the "License"). You may not use
70this file except in compliance with the License. You can obtain a copy
71in the file LICENSE in the source distribution or at
72L<https://www.openssl.org/source/license.html>.
73
74=cut