}
int
-p11_kit_pin_read_pinfile (const char *pinfile, P11KitUri *pin_uri,
- const char *pin_description, P11KitPinFlags flags,
- char *pin, size_t pin_max)
+p11_kit_pin_retrieve (const char *pinfile, P11KitUri *pin_uri,
+ const char *pin_description, P11KitPinFlags flags,
+ char *pin, size_t pin_length)
{
PinfileCallback **snapshot = NULL;
unsigned int snapshot_count = 0;
if (snapshot == NULL)
return 0;
- for (i = 0; i < snapshot_count; i++) {
- ret = (snapshot[i]->func) (pinfile, pin_uri, pin_description, flags,
- snapshot[i]->user_data, pin, pin_max);
+ ret = 0;
+ for (i = snapshot_count; ret == 0 && i > 0; i--) {
+ ret = (snapshot[i - 1]->func) (pinfile, pin_uri, pin_description, flags,
+ snapshot[i - 1]->user_data, pin, pin_length);
}
_p11_lock ();
&data, destroy_data);
uri = p11_kit_uri_new ();
- ret = p11_kit_pin_read_pinfile ("/the/pinfile", uri, "The token",
- P11_KIT_PIN_FLAGS_USER_LOGIN,
- buffer, sizeof (buffer));
+ ret = p11_kit_pin_retrieve ("/the/pinfile", uri, "The token",
+ P11_KIT_PIN_FLAGS_USER_LOGIN,
+ buffer, sizeof (buffer));
p11_kit_uri_free (uri);
CuAssertIntEquals (tc, 1, ret);
int ret;
uri = p11_kit_uri_new ();
- ret = p11_kit_pin_read_pinfile ("/the/pinfile", uri, "The token",
- P11_KIT_PIN_FLAGS_USER_LOGIN,
- buffer, sizeof (buffer));
+ ret = p11_kit_pin_retrieve ("/the/pinfile", uri, "The token",
+ P11_KIT_PIN_FLAGS_USER_LOGIN,
+ buffer, sizeof (buffer));
p11_kit_uri_free (uri);
CuAssertIntEquals (tc, 0, ret);
p11_kit_pin_register_callback ("/the/pinfile", callback_other,
value, NULL);
- ret = p11_kit_pin_read_pinfile ("/the/pinfile", uri, "The token",
- P11_KIT_PIN_FLAGS_USER_LOGIN,
- buffer, sizeof (buffer));
+ ret = p11_kit_pin_retrieve ("/the/pinfile", uri, "The token",
+ P11_KIT_PIN_FLAGS_USER_LOGIN,
+ buffer, sizeof (buffer));
CuAssertIntEquals (tc, 1, ret);
CuAssertStrEquals (tc, "secret", buffer);
p11_kit_pin_unregister_callback ("/the/pinfile", callback_other,
value);
- ret = p11_kit_pin_read_pinfile ("/the/pinfile", uri, "The token",
- P11_KIT_PIN_FLAGS_USER_LOGIN,
- buffer, sizeof (buffer));
+ ret = p11_kit_pin_retrieve ("/the/pinfile", uri, "The token",
+ P11_KIT_PIN_FLAGS_USER_LOGIN,
+ buffer, sizeof (buffer));
CuAssertIntEquals (tc, 1, ret);
CuAssertStrEquals (tc, "one", buffer);
p11_kit_pin_unregister_callback ("/the/pinfile", callback_one,
&data);
- ret = p11_kit_pin_read_pinfile ("/the/pinfile", uri, "The token",
+ ret = p11_kit_pin_retrieve ("/the/pinfile", uri, "The token",
P11_KIT_PIN_FLAGS_USER_LOGIN,
buffer, sizeof (buffer));
p11_kit_pin_register_callback (P11_KIT_PIN_FALLBACK, callback_one,
&data, destroy_data);
- ret = p11_kit_pin_read_pinfile ("/the/pinfile", uri, "The token",
- P11_KIT_PIN_FLAGS_USER_LOGIN,
- buffer, sizeof (buffer));
+ ret = p11_kit_pin_retrieve ("/the/pinfile", uri, "The token",
+ P11_KIT_PIN_FLAGS_USER_LOGIN,
+ buffer, sizeof (buffer));
CuAssertIntEquals (tc, 1, ret);
CuAssertStrEquals (tc, "one", buffer);
p11_kit_pin_register_callback ("/the/pinfile", callback_other,
value, NULL);
- ret = p11_kit_pin_read_pinfile ("/the/pinfile", uri, "The token",
- P11_KIT_PIN_FLAGS_USER_LOGIN,
- buffer, sizeof (buffer));
+ ret = p11_kit_pin_retrieve ("/the/pinfile", uri, "The token",
+ P11_KIT_PIN_FLAGS_USER_LOGIN,
+ buffer, sizeof (buffer));
CuAssertIntEquals (tc, 1, ret);
CuAssertStrEquals (tc, "secret", buffer);