summaryrefslogtreecommitdiffstats
path: root/src/util/net.h
blob: 8024956ad0cd3337ab9816a0a98ff9f831735afe (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/*
 * Copyright (C) the libgit2 contributors. All rights reserved.
 *
 * This file is part of libgit2, distributed under the GNU GPL v2 with
 * a Linking Exception. For full terms see the included COPYING file.
 */
#ifndef INCLUDE_net_h__
#define INCLUDE_net_h__

#include "git2_util.h"

/*
 * Hostname handling
 */

/*
 * See if a given hostname matches a certificate name pattern, according
 * to RFC2818 rules (which specifies HTTP over TLS). Mainly, an asterisk
 * matches anything, but is limited to a single url component.
 */
extern bool git_net_hostname_matches_cert(
	const char *hostname,
	const char *pattern);

/*
 * URL handling
 */

typedef struct git_net_url {
	char *scheme;
	char *host;
	char *port;
	char *path;
	char *query;
	char *fragment;
	char *username;
	char *password;
} git_net_url;

#define GIT_NET_URL_INIT { NULL }

/** Is a given string a url? */
extern bool git_net_str_is_url(const char *str);

/** Duplicate a URL */
extern int git_net_url_dup(git_net_url *out, git_net_url *in);

/** Parses a string containing a URL into a structure. */
extern int git_net_url_parse(git_net_url *url, const char *str);

/** Parses a string containing an SCP style path into a URL structure. */
extern int git_net_url_parse_scp(git_net_url *url, const char *str);

/**
 * Parses a string containing a standard URL or an SCP style path into
 * a URL structure.
 */
extern int git_net_url_parse_standard_or_scp(git_net_url *url, const char *str);

/**
 * Parses a string containing an HTTP endpoint that may not be a
 * well-formed URL. For example, "localhost" or "localhost:port".
 */
extern int git_net_url_parse_http(
	git_net_url *url,
	const char *str);

/** Appends a path and/or query string to the given URL */
extern int git_net_url_joinpath(
	git_net_url *out,
	git_net_url *in,
	const char *path);

/** Ensures that a URL is minimally valid (contains a host, port and path) */
extern bool git_net_url_valid(git_net_url *url);

/** Returns true if the URL is on the default port. */
extern bool git_net_url_is_default_port(git_net_url *url);

/** Returns true if the host portion of the URL is an ipv6 address. */
extern bool git_net_url_is_ipv6(git_net_url *url);

/* Applies a redirect to the URL with a git-aware service suffix. */
extern int git_net_url_apply_redirect(
	git_net_url *url,
	const char *redirect_location,
	bool allow_offsite,
	const char *service_suffix);

/** Swaps the contents of one URL for another.  */
extern void git_net_url_swap(git_net_url *a, git_net_url *b);

/** Places the URL into the given buffer. */
extern int git_net_url_fmt(git_str *out, git_net_url *url);

/** Place the path and query string into the given buffer. */
extern int git_net_url_fmt_path(git_str *buf, git_net_url *url);

/** Determines if the url matches given pattern or pattern list */
extern bool git_net_url_matches_pattern(
	git_net_url *url,
	const char *pattern);
extern bool git_net_url_matches_pattern_list(
	git_net_url *url,
	const char *pattern_list);

/** Disposes the contents of the structure. */
extern void git_net_url_dispose(git_net_url *url);

#endif