SecBSD's official ports repository

This commit is contained in:
purplerain 2023-08-16 22:26:55 +00:00
commit 2c0afcbbf3
Signed by: purplerain
GPG key ID: F42C07F07E2E35B7
64331 changed files with 5339189 additions and 0 deletions

View file

@ -0,0 +1,44 @@
Unveil the required directory with .desktop files and where the cache file needs
to be written out to.
Index: src/update-desktop-database.c
--- src/update-desktop-database.c.orig
+++ src/update-desktop-database.c
@@ -451,8 +451,8 @@ main (int argc,
{ NULL }
};
-#if HAVE_PLEDGE
- if (pledge("stdio rpath wpath cpath fattr", NULL) == -1) {
+#ifdef HAVE_PLEDGE
+ if (pledge ("stdio rpath wpath cpath fattr unveil", NULL) == -1) {
g_printerr ("pledge\n");
return 1;
}
@@ -478,9 +478,15 @@ main (int argc,
print_desktop_dirs (desktop_dirs);
+ if (unveil ("${LOCALBASE}/share/locale/locale.alias", "r") == -1) {
+ g_printerr ("Can't unveil '${LOCALBASE}/share/locale/locale.alias': %s\n", g_strerror(errno));
+ }
found_processable_dir = FALSE;
for (i = 0; desktop_dirs[i] != NULL; i++)
{
+ if (unveil (desktop_dirs[i], "rwc") == -1) {
+ g_printerr ("Can't unveil '%s' directory: %s\n", desktop_dirs[i], g_strerror(errno));
+ }
error = NULL;
update_database (desktop_dirs[i], &error);
@@ -495,6 +501,10 @@ main (int argc,
found_processable_dir = TRUE;
}
g_option_context_free (context);
+
+ if (unveil (NULL, NULL) == -1) {
+ g_printerr ("unveil\n");
+ }
if (!found_processable_dir)
{