⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 name.c

📁 samba最新软件
💻 C
📖 第 1 页 / 共 2 页
字号:
	return ENOMEM;    }    name->u.rdnSequence.val = ptr;    if (append) {	rdn = &name->u.rdnSequence.val[name->u.rdnSequence.len];    } else {	memmove(&name->u.rdnSequence.val[1],		&name->u.rdnSequence.val[0],		name->u.rdnSequence.len * 		sizeof(name->u.rdnSequence.val[0]));		rdn = &name->u.rdnSequence.val[0];    }    rdn->val = malloc(sizeof(rdn->val[0]));    if (rdn->val == NULL)	return ENOMEM;    rdn->len = 1;    ret = der_copy_oid(oid, &rdn->val[0].type);    if (ret)	return ret;    rdn->val[0].value.element = choice_DirectoryString_utf8String;    rdn->val[0].value.u.utf8String = strdup(str);    if (rdn->val[0].value.u.utf8String == NULL)	return ENOMEM;    name->u.rdnSequence.len += 1;    return 0;}/** * Parse a string into a hx509 name object. * * @param context A hx509 context. * @param str a string to parse. * @param name the resulting object, NULL in case of error. * * @return An hx509 error code, see hx509_get_error_string(). * * @ingroup hx509_name */inthx509_parse_name(hx509_context context, const char *str, hx509_name *name){    const char *p, *q;    size_t len;    hx509_name n;    int ret;    *name = NULL;    n = calloc(1, sizeof(*n));    if (n == NULL) {	hx509_set_error_string(context, 0, ENOMEM, "out of memory");	return ENOMEM;    }    n->der_name.element = choice_Name_rdnSequence;    p = str;    while (p != NULL && *p != '\0') {	heim_oid oid;	int last;	q = strchr(p, ',');	if (q) {	    len = (q - p);	    last = 1;	} else {	    len = strlen(p);	    last = 0;	}	q = strchr(p, '=');	if (q == NULL) {	    ret = HX509_PARSING_NAME_FAILED;	    hx509_set_error_string(context, 0, ret, "missing = in %s", p);	    goto out;	}	if (q == p) {	    ret = HX509_PARSING_NAME_FAILED;	    hx509_set_error_string(context, 0, ret, 				   "missing name before = in %s", p);	    goto out;	}		if ((q - p) > len) {	    ret = HX509_PARSING_NAME_FAILED;	    hx509_set_error_string(context, 0, ret, " = after , in %s", p);	    goto out;	}	ret = stringtooid(p, q - p, &oid);	if (ret) {	    ret = HX509_PARSING_NAME_FAILED;	    hx509_set_error_string(context, 0, ret, 				   "unknown type: %.*s", (int)(q - p), p);	    goto out;	}		{	    size_t pstr_len = len - (q - p) - 1;	    const char *pstr = p + (q - p) + 1;	    char *r;	    	    r = malloc(pstr_len + 1);	    if (r == NULL) {		der_free_oid(&oid);		ret = ENOMEM;		hx509_set_error_string(context, 0, ret, "out of memory");		goto out;	    }	    memcpy(r, pstr, pstr_len);	    r[pstr_len] = '\0';	    ret = _hx509_name_modify(context, &n->der_name, 0, &oid, r);	    free(r);	    der_free_oid(&oid);	    if(ret)		goto out;	}	p += len + last;    }    *name = n;    return 0;out:    hx509_name_free(&n);    return HX509_NAME_MALFORMED;}/** * Copy a hx509 name object. * * @param context A hx509 cotext. * @param from the name to copy from * @param to the name to copy to * * @return An hx509 error code, see hx509_get_error_string(). * * @ingroup hx509_name */inthx509_name_copy(hx509_context context, const hx509_name from, hx509_name *to){    int ret;    *to = calloc(1, sizeof(**to));    if (*to == NULL)	return ENOMEM;    ret = copy_Name(&from->der_name, &(*to)->der_name);    if (ret) {	free(*to);	*to = NULL;	return ENOMEM;    }    return 0;}/** * Convert a hx509_name into a Name. * * @param from the name to copy from * @param to the name to copy to * * @return An hx509 error code, see hx509_get_error_string(). * * @ingroup hx509_name */inthx509_name_to_Name(const hx509_name from, Name *to){    return copy_Name(&from->der_name, to);}inthx509_name_normalize(hx509_context context, hx509_name name){    return 0;}/** * Expands variables in the name using env. Variables are on the form * ${name}. Useful when dealing with certificate templates. * * @param context A hx509 cotext. * @param name the name to expand. * @param env environment variable to expand. * * @return An hx509 error code, see hx509_get_error_string(). * * @ingroup hx509_name */inthx509_name_expand(hx509_context context,		  hx509_name name,		  hx509_env env){    Name *n = &name->der_name;    int i, j;    if (env == NULL)	return 0;    if (n->element != choice_Name_rdnSequence) {	hx509_set_error_string(context, 0, EINVAL, "RDN not of supported type");	return EINVAL;    }    for (i = 0 ; i < n->u.rdnSequence.len; i++) {	for (j = 0; j < n->u.rdnSequence.val[i].len; j++) {	    /** Only UTF8String rdnSequence names are allowed */	    /*	      THIS SHOULD REALLY BE:	      COMP = n->u.rdnSequence.val[i].val[j];	      normalize COMP to utf8	      check if there are variables	        expand variables	        convert back to orignal format, store in COMP	      free normalized utf8 string	    */	    DirectoryString *ds = &n->u.rdnSequence.val[i].val[j].value;	    char *p, *p2;	    struct rk_strpool *strpool = NULL;	    if (ds->element != choice_DirectoryString_utf8String) {		hx509_set_error_string(context, 0, EINVAL, "unsupported type");		return EINVAL;	    }	    p = strstr(ds->u.utf8String, "${");	    if (p) {		strpool = rk_strpoolprintf(strpool, "%.*s", 					   (int)(p - ds->u.utf8String), 					   ds->u.utf8String);		if (strpool == NULL) {		    hx509_set_error_string(context, 0, ENOMEM, "out of memory");		    return ENOMEM;		}	    }	    while (p != NULL) {		/* expand variables */		const char *value;		p2 = strchr(p, '}');		if (p2 == NULL) {		    hx509_set_error_string(context, 0, EINVAL, "missing }");		    rk_strpoolfree(strpool);		    return EINVAL;		}		p += 2;		value = hx509_env_lfind(context, env, p, p2 - p);		if (value == NULL) {		    hx509_set_error_string(context, 0, EINVAL, 					   "variable %.*s missing",					   (int)(p2 - p), p);		    rk_strpoolfree(strpool);		    return EINVAL;		}		strpool = rk_strpoolprintf(strpool, "%s", value);		if (strpool == NULL) {		    hx509_set_error_string(context, 0, ENOMEM, "out of memory");		    return ENOMEM;		}		p2++;		p = strstr(p2, "${");		if (p)		    strpool = rk_strpoolprintf(strpool, "%.*s", 					       (int)(p - p2), p2);		else		    strpool = rk_strpoolprintf(strpool, "%s", p2);		if (strpool == NULL) {		    hx509_set_error_string(context, 0, ENOMEM, "out of memory");		    return ENOMEM;		}	    }	    if (strpool) {		free(ds->u.utf8String);		ds->u.utf8String = rk_strpoolcollect(strpool);		if (ds->u.utf8String == NULL) {		    hx509_set_error_string(context, 0, ENOMEM, "out of memory");		    return ENOMEM;		}	    }	}    }    return 0;}/** * Free a hx509 name object, upond return *name will be NULL. * * @param name a hx509 name object to be freed. * * @ingroup hx509_name */voidhx509_name_free(hx509_name *name){    free_Name(&(*name)->der_name);    memset(*name, 0, sizeof(**name));    free(*name);    *name = NULL;}/** * Convert a DER encoded name info a string. * * @param data data to a DER/BER encoded name * @param length length of data * @param str the resulting string, is NULL on failure. * * @return An hx509 error code, see hx509_get_error_string(). * * @ingroup hx509_name */inthx509_unparse_der_name(const void *data, size_t length, char **str){    Name name;    int ret;    *str = NULL;    ret = decode_Name(data, length, &name, NULL);    if (ret)	return ret;    ret = _hx509_Name_to_string(&name, str);    free_Name(&name);    return ret;}/** * Convert a hx509_name object to DER encoded name. * * @param name name to concert * @param os data to a DER encoded name, free the resulting octet * string with hx509_xfree(os->data). * * @return An hx509 error code, see hx509_get_error_string(). * * @ingroup hx509_name */inthx509_name_binary(const hx509_name name, heim_octet_string *os){    size_t size;    int ret;    ASN1_MALLOC_ENCODE(Name, os->data, os->length, &name->der_name, &size, ret);    if (ret)	return ret;    if (os->length != size)	_hx509_abort("internal ASN.1 encoder error");    return 0;}int_hx509_unparse_Name(const Name *aname, char **str){    hx509_name name;    int ret;    ret = _hx509_name_from_Name(aname, &name);    if (ret)	return ret;    ret = hx509_name_to_string(name, str);    hx509_name_free(&name);    return ret;}/** * Unparse the hx509 name in name into a string. * * @param name the name to check if its empty/null. * * @return non zero if the name is empty/null. * * @ingroup hx509_name */inthx509_name_is_null_p(const hx509_name name){    return name->der_name.u.rdnSequence.len == 0;}/** * Unparse the hx509 name in name into a string. * * @param name the name to print * @param str an allocated string returns the name in string form * * @return An hx509 error code, see krb5_get_error_string(). * * @ingroup hx509_name */inthx509_general_name_unparse(GeneralName *name, char **str){    struct rk_strpool *strpool = NULL;    *str = NULL;    switch (name->element) {    case choice_GeneralName_otherName: {	char *str;	hx509_oid_sprint(&name->u.otherName.type_id, &str);	if (str == NULL)	    return ENOMEM;	strpool = rk_strpoolprintf(strpool, "otherName: %s", str);	free(str);	break;    }    case choice_GeneralName_rfc822Name:	strpool = rk_strpoolprintf(strpool, "rfc822Name: %s\n",				   name->u.rfc822Name);	break;    case choice_GeneralName_dNSName:	strpool = rk_strpoolprintf(strpool, "dNSName: %s\n",				   name->u.dNSName);	break;    case choice_GeneralName_directoryName: {	Name dir;	char *s;	int ret;	memset(&dir, 0, sizeof(dir));	dir.element = name->u.directoryName.element;	dir.u.rdnSequence = name->u.directoryName.u.rdnSequence;	ret = _hx509_unparse_Name(&dir, &s);	if (ret)	    return ret;	strpool = rk_strpoolprintf(strpool, "directoryName: %s", s);	free(s);	break;    }    case choice_GeneralName_uniformResourceIdentifier:	strpool = rk_strpoolprintf(strpool, "URI: %s", 				   name->u.uniformResourceIdentifier);	break;    case choice_GeneralName_iPAddress: {	unsigned char *a = name->u.iPAddress.data;	strpool = rk_strpoolprintf(strpool, "IPAddress: ");	if (strpool == NULL)	    break;	if (name->u.iPAddress.length == 4)	    strpool = rk_strpoolprintf(strpool, "%d.%d.%d.%d", 				       a[0], a[1], a[2], a[3]);	else if (name->u.iPAddress.length == 16)	    strpool = rk_strpoolprintf(strpool, 				       "%02X:%02X:%02X:%02X:"				       "%02X:%02X:%02X:%02X:"				       "%02X:%02X:%02X:%02X:"				       "%02X:%02X:%02X:%02X", 				       a[0], a[1], a[2], a[3],				       a[4], a[5], a[6], a[7],				       a[8], a[9], a[10], a[11],				       a[12], a[13], a[14], a[15]);	else	    strpool = rk_strpoolprintf(strpool, 				       "unknown IP address of length %lu",				       (unsigned long)name->u.iPAddress.length);	break;    }    case choice_GeneralName_registeredID: {	char *str;	hx509_oid_sprint(&name->u.registeredID, &str);	if (str == NULL)	    return ENOMEM;	strpool = rk_strpoolprintf(strpool, "registeredID: %s", str);	free(str);	break;    }    default:	return EINVAL;    }    if (strpool == NULL)	return ENOMEM;    *str = rk_strpoolcollect(strpool);    return 0;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -