|
Packit Service |
b23acc |
// SPDX-License-Identifier: LGPL-2.1+
|
|
Packit Service |
b23acc |
/*
|
|
Packit Service |
b23acc |
* Copyright (C) 2018 Red Hat, Inc.
|
|
Packit Service |
b23acc |
*/
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
#include "nm-default.h"
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
#include "nm-sd-utils-shared.h"
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
#include "nm-sd-adapt-shared.h"
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
#include "dns-domain.h"
|
|
Packit Service |
b23acc |
#include "hexdecoct.h"
|
|
Packit Service |
b23acc |
#include "hostname-util.h"
|
|
Packit Service |
b23acc |
#include "path-util.h"
|
|
Packit Service |
b23acc |
#include "web-util.h"
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
/*****************************************************************************/
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
const bool mempool_use_allowed = true;
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
/*****************************************************************************/
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
gboolean
|
|
Packit Service |
b23acc |
nm_sd_utils_path_equal (const char *a, const char *b)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
return path_equal (a, b);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
char *
|
|
Packit Service |
b23acc |
nm_sd_utils_path_simplify (char *path, gboolean kill_dots)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
return path_simplify (path, kill_dots);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
const char *
|
|
Packit Service |
b23acc |
nm_sd_utils_path_startswith (const char *path, const char *prefix)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
return path_startswith (path, prefix);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
/*****************************************************************************/
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
int
|
|
Packit Service |
b23acc |
nm_sd_utils_unbase64char (char ch, gboolean accept_padding_equal)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
if ( ch == '='
|
|
Packit Service |
b23acc |
&& accept_padding_equal)
|
|
Packit Service |
b23acc |
return G_MAXINT;
|
|
Packit Service |
b23acc |
return unbase64char (ch);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
/**
|
|
Packit Service |
b23acc |
* nm_sd_utils_unbase64mem:
|
|
Packit Service |
b23acc |
* @p: a valid base64 string. Whitespace is ignored, but invalid encodings
|
|
Packit Service |
b23acc |
* will cause the function to fail.
|
|
Packit Service |
b23acc |
* @l: the length of @p. @p is not treated as NUL terminated string but
|
|
Packit Service |
b23acc |
* merely as a buffer of ascii characters.
|
|
Packit Service |
b23acc |
* @secure: whether the temporary memory will be cleared to avoid leaving
|
|
Packit Service |
b23acc |
* secrets in memory (see also nm_explict_bzero()).
|
|
Packit Service |
b23acc |
* @mem: (transfer full): the decoded buffer on success.
|
|
Packit Service |
b23acc |
* @len: the length of @mem on success.
|
|
Packit Service |
b23acc |
*
|
|
Packit Service |
b23acc |
* glib provides g_base64_decode(), but that does not report any errors
|
|
Packit Service |
b23acc |
* from invalid encodings. Expose systemd's implementation which does
|
|
Packit Service |
b23acc |
* reject invalid inputs.
|
|
Packit Service |
b23acc |
*
|
|
Packit Service |
b23acc |
* Returns: a non-negative code on success. Invalid encoding let the
|
|
Packit Service |
b23acc |
* function fail.
|
|
Packit Service |
b23acc |
*/
|
|
Packit Service |
b23acc |
int
|
|
Packit Service |
b23acc |
nm_sd_utils_unbase64mem (const char *p,
|
|
Packit Service |
b23acc |
size_t l,
|
|
Packit Service |
b23acc |
gboolean secure,
|
|
Packit Service |
b23acc |
guint8 **mem,
|
|
Packit Service |
b23acc |
size_t *len)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
return unbase64mem_full (p, l, secure, (void **) mem, len);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
int nm_sd_dns_name_to_wire_format (const char *domain,
|
|
Packit Service |
b23acc |
guint8 *buffer,
|
|
Packit Service |
b23acc |
size_t len,
|
|
Packit Service |
b23acc |
gboolean canonical)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
return dns_name_to_wire_format (domain, buffer, len, canonical);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
int nm_sd_dns_name_is_valid (const char *s)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
return dns_name_is_valid (s);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
gboolean nm_sd_hostname_is_valid (const char *s, bool allow_trailing_dot)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
return hostname_is_valid (s, allow_trailing_dot);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
/*****************************************************************************/
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
static gboolean
|
|
Packit Service |
b23acc |
_http_url_is_valid (const char *url, gboolean only_https)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
if ( !url
|
|
Packit Service |
b23acc |
|| !url[0])
|
|
Packit Service |
b23acc |
return FALSE;
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
if ( !only_https
|
|
Packit Service |
b23acc |
&& NM_STR_HAS_PREFIX (url, "http://"))
|
|
Packit Service |
b23acc |
url += NM_STRLEN ("http://");
|
|
Packit Service |
b23acc |
else if (NM_STR_HAS_PREFIX (url, "https://"))
|
|
Packit Service |
b23acc |
url += NM_STRLEN ("https://");
|
|
Packit Service |
b23acc |
else
|
|
Packit Service |
b23acc |
return FALSE;
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
if (!url[0])
|
|
Packit Service |
b23acc |
return FALSE;
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
return !NM_STRCHAR_ANY (url, ch, (guchar) ch >= 128u);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
gboolean
|
|
Packit Service |
b23acc |
nm_sd_http_url_is_valid_https (const char *url)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
/* We use this function to verify connection:mud-url property, it must thus
|
|
Packit Service |
b23acc |
* not change behavior.
|
|
Packit Service |
b23acc |
*
|
|
Packit Service |
b23acc |
* Note that sd_dhcp_client_set_mud_url() and sd_dhcp6_client_set_request_mud_url()
|
|
Packit Service |
b23acc |
* assert with http_url_is_valid() that the argument is valid. We thus must make
|
|
Packit Service |
b23acc |
* sure to only pass URLs that are valid according to http_url_is_valid().
|
|
Packit Service |
b23acc |
*
|
|
Packit Service |
b23acc |
* This is given, because our nm_sd_http_url_is_valid_https() is more strict
|
|
Packit Service |
b23acc |
* than http_url_is_valid().
|
|
Packit Service |
b23acc |
*
|
|
Packit Service |
b23acc |
* We only must make sure that this is also correct in the future, when we
|
|
Packit Service |
b23acc |
* re-import systemd code. */
|
|
Packit Service |
b23acc |
nm_assert (_http_url_is_valid (url, FALSE) == http_url_is_valid (url));
|
|
Packit Service |
b23acc |
return _http_url_is_valid (url, TRUE);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
/*****************************************************************************/
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
int
|
|
Packit Service |
b23acc |
nmtst_systemd_extract_first_word_all (const char *str, char ***out_strv)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
gs_unref_ptrarray GPtrArray *arr = NULL;
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
/* we implement a str split function to parse `/proc/cmdline`. This
|
|
Packit Service |
b23acc |
* code should behave like systemd, which uses extract_first_word()
|
|
Packit Service |
b23acc |
* for that.
|
|
Packit Service |
b23acc |
*
|
|
Packit Service |
b23acc |
* As we want to unit-test our implementation to match systemd,
|
|
Packit Service |
b23acc |
* expose this function for testing. */
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
g_assert (out_strv);
|
|
Packit Service |
b23acc |
g_assert (!*out_strv);
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
if (!str)
|
|
Packit Service |
b23acc |
return 0;
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
arr = g_ptr_array_new_with_free_func (g_free);
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
for (;;) {
|
|
Packit Service |
b23acc |
gs_free char *word = NULL;
|
|
Packit Service |
b23acc |
int r;
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
r = extract_first_word (&str, &word, NULL, EXTRACT_UNQUOTE | EXTRACT_RELAX);
|
|
Packit Service |
b23acc |
if (r < 0)
|
|
Packit Service |
b23acc |
return r;
|
|
Packit Service |
b23acc |
if (r == 0)
|
|
Packit Service |
b23acc |
break;
|
|
Packit Service |
b23acc |
g_ptr_array_add (arr, g_steal_pointer (&word));
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
g_ptr_array_add (arr, NULL);
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
*out_strv = (char **) g_ptr_array_free (g_steal_pointer (&arr), FALSE);
|
|
Packit Service |
b23acc |
return 1;
|
|
Packit Service |
b23acc |
}
|