X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fwgtpkg-permissions.c;h=abb4596a76a48e2aa75e37f282680da9530eec67;hb=2a319cf90daa6e3b01e8139923f7073e1c9bcf28;hp=6aed31f3aab2e111449aaad621c5d65c91a08cc9;hpb=8afd46f28a677c40a482ccd18ca5568cf6c0f6aa;p=src%2Fapp-framework-main.git diff --git a/src/wgtpkg-permissions.c b/src/wgtpkg-permissions.c index 6aed31f..abb4596 100644 --- a/src/wgtpkg-permissions.c +++ b/src/wgtpkg-permissions.c @@ -1,5 +1,5 @@ /* - Copyright 2015 IoT.bzh + Copyright (C) 2015-2019 IoT.bzh author: José Bollo @@ -32,18 +32,10 @@ struct permission { unsigned level: 3; }; -static const char prefix_of_permissions[] = FWK_PREFIX_PERMISSION; - static unsigned int nrpermissions = 0; static struct permission *permissions = NULL; static unsigned int indexiter = 0; -/* check is the name has the correct prefix for permissions */ -int is_standard_permission(const char *name) -{ - return 0 == memcmp(name, prefix_of_permissions, sizeof(prefix_of_permissions) - 1); -} - /* retrieves the permission of name */ static struct permission *get_permission(const char *name) { @@ -81,7 +73,15 @@ void reset_permissions() { unsigned int i; for (i = 0 ; i < nrpermissions ; i++) - permissions[i].granted = 0; + permissions[i].granted = permissions[i].requested = 0; +} + +/* remove any requested permission */ +void reset_requested_permissions() +{ + unsigned int i; + for (i = 0 ; i < nrpermissions ; i++) + permissions[i].requested = 0; } /* remove any granting */ @@ -129,13 +129,25 @@ int permission_exists(const char *name) /* request the permission, returns 1 if granted or 0 otherwise */ int request_permission(const char *name) { +#define HACK_ALLOWING_REQUESTED_PERMISSIONS 1 + struct permission *p = get_permission(name); + +#if defined(HACK_ALLOWING_REQUESTED_PERMISSIONS) && HACK_ALLOWING_REQUESTED_PERMISSIONS + if (!p) + p = add_permission(name); +#endif if (p) { +#if defined(HACK_ALLOWING_REQUESTED_PERMISSIONS) && HACK_ALLOWING_REQUESTED_PERMISSIONS + p->granted = 1; +#endif p->requested = 1; if (p->granted) return 1; } return 0; + +#undef HACK_ALLOWING_REQUESTED_PERMISSIONS } /* iteration over granted and requested permissions */