diff options
-rw-r--r-- | p11-kit/test-uri.c | 2 | ||||
-rw-r--r-- | p11-kit/uri.c | 81 |
2 files changed, 48 insertions, 35 deletions
diff --git a/p11-kit/test-uri.c b/p11-kit/test-uri.c index 7c38e60..b17001f 100644 --- a/p11-kit/test-uri.c +++ b/p11-kit/test-uri.c @@ -1368,7 +1368,7 @@ test_uri_pin_value (void) ret = p11_kit_uri_format (uri, P11_KIT_URI_FOR_ANY, &string); assert_num_eq (P11_KIT_URI_OK, ret); - assert (strstr (string, "pkcs11:pin-value=1%2a%26%23%25%26%40%28") != NULL); + assert (strstr (string, "pkcs11:?pin-value=1%2a%26%23%25%26%40%28") != NULL); free (string); ret = p11_kit_uri_parse ("pkcs11:?pin-value=blah%2Fblah", P11_KIT_URI_FOR_ANY, uri); diff --git a/p11-kit/uri.c b/p11-kit/uri.c index 832980d..75d2e84 100644 --- a/p11-kit/uri.c +++ b/p11-kit/uri.c @@ -753,21 +753,32 @@ p11_kit_uri_new (void) return uri; } +enum uri_sep { + sep_path = '\0', + sep_pattr = ';', + sep_query = '?', + sep_qattr = '&', +}; + static void format_name_equals (p11_buffer *buffer, - bool *is_first, + enum uri_sep *sep, const char *name) { - if (!*is_first) - p11_buffer_add (buffer, ";", 1); + if (*sep) + p11_buffer_add (buffer, sep, 1); p11_buffer_add (buffer, name, -1); p11_buffer_add (buffer, "=", 1); - *is_first = false; + + if (*sep == sep_path) + *sep = sep_pattr; + else if (*sep == sep_query) + *sep = sep_qattr; } static bool format_raw_string (p11_buffer *buffer, - bool *is_first, + enum uri_sep *sep, const char *name, const char *value) { @@ -775,7 +786,7 @@ format_raw_string (p11_buffer *buffer, if (!value) return true; - format_name_equals (buffer, is_first, name); + format_name_equals (buffer, sep, name); p11_buffer_add (buffer, value, -1); return p11_buffer_ok (buffer); @@ -783,7 +794,7 @@ format_raw_string (p11_buffer *buffer, static bool format_encode_string (p11_buffer *buffer, - bool *is_first, + enum uri_sep *sep, const char *name, const unsigned char *value, size_t n_value, @@ -793,7 +804,7 @@ format_encode_string (p11_buffer *buffer, if (!value) return true; - format_name_equals (buffer, is_first, name); + format_name_equals (buffer, sep, name); p11_url_encode (value, value + n_value, force ? "" : P11_URL_VERBATIM, buffer); return p11_buffer_ok (buffer); @@ -802,7 +813,7 @@ format_encode_string (p11_buffer *buffer, static bool format_struct_string (p11_buffer *buffer, - bool *is_first, + enum uri_sep *sep, const char *name, const unsigned char *value, size_t value_max) @@ -814,12 +825,12 @@ format_struct_string (p11_buffer *buffer, return true; len = p11_kit_space_strlen (value, value_max); - return format_encode_string (buffer, is_first, name, value, len, false); + return format_encode_string (buffer, sep, name, value, len, false); } static bool format_attribute_string (p11_buffer *buffer, - bool *is_first, + enum uri_sep *sep, const char *name, CK_ATTRIBUTE_PTR attr, bool force) @@ -828,14 +839,14 @@ format_attribute_string (p11_buffer *buffer, if (attr == NULL) return true; - return format_encode_string (buffer, is_first, name, + return format_encode_string (buffer, sep, name, attr->pValue, attr->ulValueLen, force); } static bool format_attribute_class (p11_buffer *buffer, - bool *is_first, + enum uri_sep *sep, const char *name, CK_ATTRIBUTE_PTR attr) { @@ -867,12 +878,12 @@ format_attribute_class (p11_buffer *buffer, return true; } - return format_raw_string (buffer, is_first, name, value); + return format_raw_string (buffer, sep, name, value); } static bool format_struct_version (p11_buffer *buffer, - bool *is_first, + enum uri_sep *sep, const char *name, CK_VERSION_PTR version) { @@ -884,12 +895,12 @@ format_struct_version (p11_buffer *buffer, snprintf (buf, sizeof (buf), "%d.%d", (int)version->major, (int)version->minor); - return format_raw_string (buffer, is_first, name, buf); + return format_raw_string (buffer, sep, name, buf); } static bool format_ulong (p11_buffer *buffer, - bool *is_first, + enum uri_sep *sep, const char *name, CK_ULONG value) { @@ -900,7 +911,7 @@ format_ulong (p11_buffer *buffer, return true; snprintf (buf, sizeof (buf), "%lu", value); - return format_raw_string (buffer, is_first, name, buf); + return format_raw_string (buffer, sep, name, buf); } /** @@ -935,7 +946,7 @@ int p11_kit_uri_format (P11KitUri *uri, P11KitUriType uri_type, char **string) { p11_buffer buffer; - bool is_first = true; + enum uri_sep sep = sep_path; return_val_if_fail (uri != NULL, P11_KIT_URI_UNEXPECTED); return_val_if_fail (string != NULL, P11_KIT_URI_UNEXPECTED); @@ -947,10 +958,10 @@ p11_kit_uri_format (P11KitUri *uri, P11KitUriType uri_type, char **string) p11_buffer_add (&buffer, ":", 1); if ((uri_type & P11_KIT_URI_FOR_MODULE) == P11_KIT_URI_FOR_MODULE) { - if (!format_struct_string (&buffer, &is_first, "library-description", + if (!format_struct_string (&buffer, &sep, "library-description", uri->module.libraryDescription, sizeof (uri->module.libraryDescription)) || - !format_struct_string (&buffer, &is_first, "library-manufacturer", + !format_struct_string (&buffer, &sep, "library-manufacturer", uri->module.manufacturerID, sizeof (uri->module.manufacturerID))) { return_val_if_reached (P11_KIT_URI_UNEXPECTED); @@ -958,36 +969,36 @@ p11_kit_uri_format (P11KitUri *uri, P11KitUriType uri_type, char **string) } if ((uri_type & P11_KIT_URI_FOR_MODULE_WITH_VERSION) == P11_KIT_URI_FOR_MODULE_WITH_VERSION) { - if (!format_struct_version (&buffer, &is_first, "library-version", + if (!format_struct_version (&buffer, &sep, "library-version", &uri->module.libraryVersion)) { return_val_if_reached (P11_KIT_URI_UNEXPECTED); } } if ((uri_type & P11_KIT_URI_FOR_SLOT) == P11_KIT_URI_FOR_SLOT) { - if (!format_struct_string (&buffer, &is_first, "slot-description", + if (!format_struct_string (&buffer, &sep, "slot-description", uri->slot.slotDescription, sizeof (uri->slot.slotDescription)) || - !format_struct_string (&buffer, &is_first, "slot-manufacturer", + !format_struct_string (&buffer, &sep, "slot-manufacturer", uri->slot.manufacturerID, sizeof (uri->slot.manufacturerID)) || - !format_ulong (&buffer, &is_first, "slot-id", + !format_ulong (&buffer, &sep, "slot-id", uri->slot_id)) { return_val_if_reached (P11_KIT_URI_UNEXPECTED); } } if ((uri_type & P11_KIT_URI_FOR_TOKEN) == P11_KIT_URI_FOR_TOKEN) { - if (!format_struct_string (&buffer, &is_first, "model", + if (!format_struct_string (&buffer, &sep, "model", uri->token.model, sizeof (uri->token.model)) || - !format_struct_string (&buffer, &is_first, "manufacturer", + !format_struct_string (&buffer, &sep, "manufacturer", uri->token.manufacturerID, sizeof (uri->token.manufacturerID)) || - !format_struct_string (&buffer, &is_first, "serial", + !format_struct_string (&buffer, &sep, "serial", uri->token.serialNumber, sizeof (uri->token.serialNumber)) || - !format_struct_string (&buffer, &is_first, "token", + !format_struct_string (&buffer, &sep, "token", uri->token.label, sizeof (uri->token.label))) { return_val_if_reached (P11_KIT_URI_UNEXPECTED); @@ -995,23 +1006,25 @@ p11_kit_uri_format (P11KitUri *uri, P11KitUriType uri_type, char **string) } if ((uri_type & P11_KIT_URI_FOR_OBJECT) == P11_KIT_URI_FOR_OBJECT) { - if (!format_attribute_string (&buffer, &is_first, "id", + if (!format_attribute_string (&buffer, &sep, "id", p11_kit_uri_get_attribute (uri, CKA_ID), true) || - !format_attribute_string (&buffer, &is_first, "object", + !format_attribute_string (&buffer, &sep, "object", p11_kit_uri_get_attribute (uri, CKA_LABEL), false)) { return_val_if_reached (P11_KIT_URI_UNEXPECTED); } - if (!format_attribute_class (&buffer, &is_first, "type", + if (!format_attribute_class (&buffer, &sep, "type", p11_kit_uri_get_attribute (uri, CKA_CLASS))) { return_val_if_reached (P11_KIT_URI_UNEXPECTED); } } + sep = sep_query; + if (uri->pin_source) { - if (!format_encode_string (&buffer, &is_first, "pin-source", + if (!format_encode_string (&buffer, &sep, "pin-source", (const unsigned char*)uri->pin_source, strlen (uri->pin_source), 0)) { return_val_if_reached (P11_KIT_URI_UNEXPECTED); @@ -1019,7 +1032,7 @@ p11_kit_uri_format (P11KitUri *uri, P11KitUriType uri_type, char **string) } if (uri->pin_value) { - if (!format_encode_string (&buffer, &is_first, "pin-value", + if (!format_encode_string (&buffer, &sep, "pin-value", (const unsigned char*)uri->pin_value, strlen (uri->pin_value), 0)) { return_val_if_reached (P11_KIT_URI_UNEXPECTED); |