4 #include "string-list.h"
8 /* normalized url on success, must be freed, otherwise NULL */
10 /* if !url, a brief reason for the failure, otherwise NULL */
13 /* the rest of the fields are only set if url != NULL */
15 size_t url_len
; /* total length of url (which is now normalized) */
16 size_t scheme_len
; /* length of scheme name (excluding final :) */
17 size_t user_off
; /* offset into url to start of user name (0 => none) */
18 size_t user_len
; /* length of user name; if user_off != 0 but
19 user_len == 0, an empty user name was given */
20 size_t passwd_off
; /* offset into url to start of passwd (0 => none) */
21 size_t passwd_len
; /* length of passwd; if passwd_off != 0 but
22 passwd_len == 0, an empty passwd was given */
23 size_t host_off
; /* offset into url to start of host name (0 => none) */
24 size_t host_len
; /* length of host name;
25 * file urls may have host_len == 0 */
26 size_t port_off
; /* offset into url to start of port number (0 => none) */
27 size_t port_len
; /* if a portnum is present (port_off != 0), it has
28 * this length (excluding the leading ':') starting
29 * from port_off (always 0 for file urls) */
30 size_t path_off
; /* offset into url to the start of the url path;
31 * this will always point to a '/' character
32 * after the url has been normalized */
33 size_t path_len
; /* length of path portion excluding any trailing
34 * '?...' and '#...' portion; will always be >= 1 */
37 char *url_normalize(const char *, struct url_info
*);
39 struct urlmatch_item
{
45 struct urlmatch_config
{
46 struct string_list vars
;
52 config_fn_t collect_fn
;
53 config_fn_t cascade_fn
;
55 * Compare the two matches, the one just discovered and the existing
56 * best match and return a negative value if the found item is to be
57 * rejected or a non-negative value if it is to be accepted. If this
58 * field is set to NULL, use the default comparison technique, which
59 * checks to ses if found is better (according to the urlmatch
60 * specificity rules) than existing.
62 int (*select_fn
)(const struct urlmatch_item
*found
, const struct urlmatch_item
*existing
);
64 * An optional callback to allow e.g. for partial URLs; it shall
65 * return 1 or 0 depending whether `url` matches or not.
67 int (*fallback_match_fn
)(const char *url
, void *cb
);
70 #define URLMATCH_CONFIG_INIT { \
71 .vars = STRING_LIST_INIT_DUP, \
74 int urlmatch_config_entry(const char *var
, const char *value
,
75 const struct config_context
*ctx
, void *cb
);
76 void urlmatch_config_release(struct urlmatch_config
*config
);
78 #endif /* URL_MATCH_H */