/* SSSD Authors: Lukas Slebodnik Copyright (C) 2014 Red Hat This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include "util/util.h" static char *replace_char(TALLOC_CTX *mem_ctx, const char *in, const char match, const char sub) { char *p; char *out; out = talloc_strdup(mem_ctx, in); if (out == NULL) { return NULL; } for (p = out; *p != '\0'; ++p) { if (*p == match) { *p = sub; } } return out; } char * sss_replace_space(TALLOC_CTX *mem_ctx, const char *orig_name, const char subst) { if (subst == '\0' || subst == ' ') { return talloc_strdup(mem_ctx, orig_name); } if (strchr(orig_name, subst) != NULL) { DEBUG(SSSDBG_CRIT_FAILURE, "Input [%s] already contains replacement character [%c].\n", orig_name, subst); sss_log(SSS_LOG_CRIT, "Name [%s] already contains replacement character [%c]. " \ "No replacement will be done.\n", orig_name, subst); return talloc_strdup(mem_ctx, orig_name); } return replace_char(mem_ctx, orig_name, ' ', subst); } char * sss_reverse_replace_space(TALLOC_CTX *mem_ctx, const char *orig_name, const char subst) { if (subst == '\0' || subst == ' ') { return talloc_strdup(mem_ctx, orig_name); } if (strchr(orig_name, subst) != NULL && strchr(orig_name, ' ') != NULL) { DEBUG(SSSDBG_TRACE_FUNC, "Input [%s] contains replacement character [%c] and space.\n", orig_name, subst); return talloc_strdup(mem_ctx, orig_name); } return replace_char(mem_ctx, orig_name, subst, ' '); } errno_t guid_blob_to_string_buf(const uint8_t *blob, char *str_buf, size_t buf_size) { int ret; if (blob == NULL || str_buf == NULL || buf_size < GUID_STR_BUF_SIZE) { DEBUG(SSSDBG_CRIT_FAILURE, "Buffer too small.\n"); return EINVAL; } ret = snprintf(str_buf, buf_size, "%02x%02x%02x%02x-%02x%02x-%02x%02x-%02x%02x-%02x%02x%02x%02x%02x%02x", blob[3], blob[2], blob[1], blob[0], blob[5], blob[4], blob[7], blob[6], blob[8], blob[9], blob[10], blob[11],blob[12], blob[13],blob[14], blob[15]);; if (ret != (GUID_STR_BUF_SIZE -1)) { DEBUG(SSSDBG_CRIT_FAILURE, "snprintf failed.\n"); return EIO; } return EOK; } const char *get_last_x_chars(const char *str, size_t x) { size_t len; if (str == NULL) { return NULL; } len = strlen(str); if (len < x) { return str; } return (str + len - x); } char **concatenate_string_array(TALLOC_CTX *mem_ctx, char **arr1, size_t len1, char **arr2, size_t len2) { size_t i, j; size_t new_size = len1 + len2; char ** string_array = talloc_realloc(mem_ctx, arr1, char *, new_size + 1); if (string_array == NULL) { return NULL; } for (i=len1, j=0; i < new_size; ++i,++j) { string_array[i] = talloc_steal(string_array, arr2[j]); } string_array[i] = NULL; return string_array; }