+ if (rule->devpath_operation != KEY_OP_UNSET) {
+ dbg("check for " KEY_DEVPATH " rule->devpath='%s' udev->devpath='%s'",
+ rule->devpath, udev->devpath);
+ if (strcmp_pattern(rule->devpath, udev->devpath) != 0) {
+ dbg(KEY_DEVPATH " is not matching");
+ if (rule->devpath_operation != KEY_OP_NOMATCH)
+ goto exit;
+ } else {
+ dbg(KEY_DEVPATH " matches");
+ if (rule->devpath_operation == KEY_OP_NOMATCH)
+ goto exit;
+ }
+ dbg(KEY_DEVPATH " key is true");
+ }
+
+ if (rule->modalias_operation != KEY_OP_UNSET) {
+ char value[NAME_SIZE];
+
+ if (find_sysfs_attribute(NULL, sysfs_device, "modalias", value, sizeof(value)) != 0) {
+ dbg(KEY_MODALIAS " value not found");
+ goto exit;
+ }
+ dbg("check for " KEY_MODALIAS " rule->modalias='%s' modalias='%s'",
+ rule->modalias, value);
+ if (strcmp_pattern(rule->modalias, value) != 0) {
+ dbg(KEY_MODALIAS " is not matching");
+ if (rule->modalias_operation != KEY_OP_NOMATCH)
+ goto exit;
+ } else {
+ dbg(KEY_MODALIAS " matches");
+ if (rule->modalias_operation == KEY_OP_NOMATCH)
+ goto exit;
+ }
+ dbg(KEY_MODALIAS " key is true");
+ }
+
+ if (rule->env_pair_count) {
+ int i;
+
+ dbg("check for " KEY_ENV " pairs");
+ for (i = 0; i < rule->env_pair_count; i++) {
+ struct key_pair *pair;
+ const char *value;
+
+ pair = &rule->env_pair[i];
+ value = getenv(pair->name);
+ if (!value) {
+ dbg(KEY_ENV "{'%s'} is not found", pair->name);
+ goto exit;
+ }
+ if (strcmp_pattern(pair->value, value) != 0) {
+ dbg(KEY_ENV "{'%s'} is not matching", pair->name);
+ if (pair->operation != KEY_OP_NOMATCH)
+ goto exit;
+ } else {
+ dbg(KEY_ENV "{'%s'} matches", pair->name);
+ if (pair->operation == KEY_OP_NOMATCH)
+ goto exit;
+ }
+ }
+ dbg(KEY_ENV " key is true");
+ }
+