mirror of
https://gitlab.com/mishakmak/pam-fprint-grosshack.git
synced 2026-04-08 20:03:34 +02:00
utils/delete: Add ability to delete single user fingerprints by finger name
Each user can now be followed by an `-f`/`--finger` parameter that when available will be used to delete a single fingerprint for the user. Add tests
This commit is contained in:
@ -2936,6 +2936,50 @@ class FPrintdUtilsTest(FPrintdVirtualStorageDeviceBaseTest):
|
|||||||
self.assertNotEqual(delete.wait(), 0)
|
self.assertNotEqual(delete.wait(), 0)
|
||||||
self.assertLess(delete.wait(), 128)
|
self.assertLess(delete.wait(), 128)
|
||||||
|
|
||||||
|
def test_delete_single_finger(self):
|
||||||
|
self.device.Claim('(s)', 'testuser')
|
||||||
|
enrolled, enroll_map = self.enroll_multiple_images()
|
||||||
|
self.addCleanup(self.try_release)
|
||||||
|
self.device.Release()
|
||||||
|
|
||||||
|
finger_name = enrolled[0]
|
||||||
|
delete, out = self.util_start('delete', ['testuser',
|
||||||
|
'-f', finger_name])
|
||||||
|
|
||||||
|
out.check_line('Using device {}'.format(
|
||||||
|
self.device.get_object_path()), get_timeout())
|
||||||
|
|
||||||
|
out.check_line('Fingerprint {} of user {} deleted on {}'.format(
|
||||||
|
finger_name, 'testuser', self.driver_name), get_timeout())
|
||||||
|
self.assertEqual(delete.wait(), 0)
|
||||||
|
|
||||||
|
remaining = self.device.ListEnrolledFingers('(s)', 'testuser')
|
||||||
|
self.assertNotIn(finger_name, remaining)
|
||||||
|
self.assertCountEqual(enrolled[1:], remaining)
|
||||||
|
|
||||||
|
def test_delete_multiple_users_single_finger(self):
|
||||||
|
self.addCleanup(self.try_release)
|
||||||
|
enroll_map, enrolled_prints_info = self.enroll_users_images()
|
||||||
|
delete_args = []
|
||||||
|
for user, print_info in enroll_map.items():
|
||||||
|
for f in print_info:
|
||||||
|
delete_args.append(user)
|
||||||
|
delete_args.append('-f')
|
||||||
|
delete_args.append(f)
|
||||||
|
|
||||||
|
delete, out = self.util_start('delete', delete_args)
|
||||||
|
out.check_line('Using device {}'.format(
|
||||||
|
self.device.get_object_path()), get_timeout())
|
||||||
|
|
||||||
|
for user, print_info in enroll_map.items():
|
||||||
|
for f in print_info:
|
||||||
|
out.check_line('Fingerprint {} of user {} deleted on {}'.format(
|
||||||
|
f, user, self.driver_name), get_timeout())
|
||||||
|
|
||||||
|
self.assertEqual(delete.wait(), 0)
|
||||||
|
with self.assertFprintError('NoEnrolledPrints'):
|
||||||
|
self.device.ListEnrolledFingers('(s)', 'testuser')
|
||||||
|
|
||||||
def test_enroll(self):
|
def test_enroll(self):
|
||||||
self.device.Claim('(s)', self.get_current_user())
|
self.device.Claim('(s)', self.get_current_user())
|
||||||
self.set_keep_alive(True)
|
self.set_keep_alive(True)
|
||||||
|
|||||||
@ -160,7 +160,7 @@ class TestFprintdUtils(TestFprintdUtilsBase):
|
|||||||
def test_fprintd_delete(self):
|
def test_fprintd_delete(self):
|
||||||
# Delete fingerprints
|
# Delete fingerprints
|
||||||
out, ret = self.run_utility_process('delete', ['toto'])
|
out, ret = self.run_utility_process('delete', ['toto'])
|
||||||
self.assertRegex(out, rb'Fingerprints deleted')
|
self.assertRegex(out, rb'Fingerprints of user toto deleted')
|
||||||
self.assertEqual(ret, 0)
|
self.assertEqual(ret, 0)
|
||||||
|
|
||||||
# Doesn't have fingerprints
|
# Doesn't have fingerprints
|
||||||
|
|||||||
@ -50,8 +50,23 @@ create_manager (void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
delete_user_prints (FprintDBusDevice *dev,
|
||||||
|
const char *fingername,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
if (fingername)
|
||||||
|
return fprint_dbus_device_call_delete_enrolled_finger_sync (dev, fingername,
|
||||||
|
NULL, error);
|
||||||
|
else
|
||||||
|
return fprint_dbus_device_call_delete_enrolled_fingers2_sync (dev, NULL,
|
||||||
|
error);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
delete_fingerprints (FprintDBusDevice *dev, const char *username)
|
delete_fingerprints (FprintDBusDevice *dev,
|
||||||
|
const char *username,
|
||||||
|
const char *fingername)
|
||||||
{
|
{
|
||||||
g_autoptr(GError) error = NULL;
|
g_autoptr(GError) error = NULL;
|
||||||
|
|
||||||
@ -61,8 +76,7 @@ delete_fingerprints (FprintDBusDevice *dev, const char *username)
|
|||||||
exit (1);
|
exit (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!fprint_dbus_device_call_delete_enrolled_fingers2_sync (dev, NULL,
|
if (!delete_user_prints (dev, fingername, &error))
|
||||||
&error))
|
|
||||||
{
|
{
|
||||||
gboolean ignore_error = FALSE;
|
gboolean ignore_error = FALSE;
|
||||||
if (g_dbus_error_is_remote_error (error))
|
if (g_dbus_error_is_remote_error (error))
|
||||||
@ -91,7 +105,12 @@ delete_fingerprints (FprintDBusDevice *dev, const char *username)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
g_print ("Fingerprints deleted on %s\n",
|
if (fingername)
|
||||||
|
g_print ("Fingerprint %s of user %s deleted on %s\n",
|
||||||
|
fingername, username,
|
||||||
|
fprint_dbus_device_get_name (dev));
|
||||||
|
else
|
||||||
|
g_print ("Fingerprints of user %s deleted on %s\n", username,
|
||||||
fprint_dbus_device_get_name (dev));
|
fprint_dbus_device_get_name (dev));
|
||||||
}
|
}
|
||||||
g_clear_error (&error);
|
g_clear_error (&error);
|
||||||
@ -104,10 +123,12 @@ delete_fingerprints (FprintDBusDevice *dev, const char *username)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
process_devices (char **argv)
|
process_devices (guint argc, char **argv)
|
||||||
{
|
{
|
||||||
|
g_autoptr(GOptionContext) option_context = NULL;
|
||||||
g_autoptr(GError) error = NULL;
|
g_autoptr(GError) error = NULL;
|
||||||
g_auto(GStrv) devices = NULL;
|
g_auto(GStrv) devices = NULL;
|
||||||
|
char *fingername = NULL;
|
||||||
char *path;
|
char *path;
|
||||||
guint num_devices;
|
guint num_devices;
|
||||||
guint i;
|
guint i;
|
||||||
@ -133,6 +154,15 @@ process_devices (char **argv)
|
|||||||
g_print ("Device at %s\n", path);
|
g_print ("Device at %s\n", path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const GOptionEntry user_options[] = {
|
||||||
|
{ "finger", 'f', 0, G_OPTION_ARG_STRING, &fingername, "Finger selected to verify (default is automatic)", NULL },
|
||||||
|
{ NULL }
|
||||||
|
};
|
||||||
|
|
||||||
|
option_context = g_option_context_new (NULL);
|
||||||
|
g_option_context_add_main_entries (option_context, user_options, NULL);
|
||||||
|
|
||||||
for (i = 0; devices[i] != NULL; i++)
|
for (i = 0; devices[i] != NULL; i++)
|
||||||
{
|
{
|
||||||
g_autoptr(FprintDBusDevice) dev = NULL;
|
g_autoptr(FprintDBusDevice) dev = NULL;
|
||||||
@ -148,7 +178,39 @@ process_devices (char **argv)
|
|||||||
path, NULL, NULL);
|
path, NULL, NULL);
|
||||||
|
|
||||||
for (j = 1; argv[j] != NULL; j++)
|
for (j = 1; argv[j] != NULL; j++)
|
||||||
delete_fingerprints (dev, argv[j]);
|
{
|
||||||
|
const char *username = argv[j];
|
||||||
|
fingername = NULL;
|
||||||
|
|
||||||
|
if (argc > j + 1 && argv[j + 1][0] == '-')
|
||||||
|
{
|
||||||
|
g_autoptr(GError) local_error = NULL;
|
||||||
|
g_autoptr(GPtrArray) user_args = NULL;
|
||||||
|
|
||||||
|
user_args = g_ptr_array_new_full (3, NULL);
|
||||||
|
g_ptr_array_add (user_args, argv[j]);
|
||||||
|
g_ptr_array_add (user_args, argv[j + 1]);
|
||||||
|
|
||||||
|
if (argc > j + 2)
|
||||||
|
g_ptr_array_add (user_args, argv[j + 2]);
|
||||||
|
|
||||||
|
int new_argc = user_args->len;
|
||||||
|
char **new_argv = (char **) user_args->pdata;
|
||||||
|
|
||||||
|
if (!g_option_context_parse (option_context, &new_argc,
|
||||||
|
&new_argv, &local_error))
|
||||||
|
{
|
||||||
|
g_print ("couldn't parse command-line options: %s\n",
|
||||||
|
local_error->message);
|
||||||
|
j += 1;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
j += 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
delete_fingerprints (dev, username, fingername);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -164,7 +226,7 @@ main (int argc, char **argv)
|
|||||||
|
|
||||||
g_option_context_set_ignore_unknown_options (option_context, TRUE);
|
g_option_context_set_ignore_unknown_options (option_context, TRUE);
|
||||||
g_option_context_set_summary (option_context,
|
g_option_context_set_summary (option_context,
|
||||||
"<username> [usernames ...]");
|
"<username> [-f finger-name [usernames [-f finger-name ]...]");
|
||||||
|
|
||||||
if (!g_option_context_parse (option_context, &argc, &argv, &local_error))
|
if (!g_option_context_parse (option_context, &argc, &argv, &local_error))
|
||||||
{
|
{
|
||||||
@ -182,7 +244,7 @@ main (int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
create_manager ();
|
create_manager ();
|
||||||
process_devices (argv);
|
process_devices (argc, argv);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user