summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLionir <git@thelion.website>2021-10-11 17:51:59 -0400
committerAlexander Larsson <alexander.larsson@gmail.com>2021-11-15 11:07:57 +0100
commit0fda062c96a44a78ac0480da5e270ea60c837fe6 (patch)
treeb4041e73d850f4cb1bb9e28158cc690cdda16eea
parent17fbe516c4251c08a648f5e938af3af78fbd4ab4 (diff)
downloadflatpak-0fda062c96a44a78ac0480da5e270ea60c837fe6.tar.gz
Add XDG_STATE_HOME and HOST_XDG_STATE_HOME env variables
This gives new support for the new XDG_STATE_HOME addition to XDG_BASE_DIRS which allows applications to use this without breaking because they would assume $HOME/.local/state which may be unavailable to the flatpak This adds it as .local/state as to make --persist=.local/state the same behaviour as in new flatpak. This in turn means that the transition should be seamless between old and new flatpak. This also has the benefit of working if the application doesn't follow XDG spec thanks to --persist=.local/state. This fixes https://github.com/flatpak/flatpak/issues/4477 [smcv: Don't call nonexistent g_get_user_state_dir(); fix a reference to XDG_STATE_DIR]
-rw-r--r--common/flatpak-run.c5
-rw-r--r--doc/flatpak-run.xml2
-rw-r--r--tests/libtest.sh1
-rw-r--r--tests/testlib.c7
-rw-r--r--tests/testlibrary.c6
5 files changed, 21 insertions, 0 deletions
diff --git a/common/flatpak-run.c b/common/flatpak-run.c
index b1226728..41a91ade 100644
--- a/common/flatpak-run.c
+++ b/common/flatpak-run.c
@@ -1842,13 +1842,16 @@ flatpak_run_apply_env_appid (FlatpakBwrap *bwrap,
g_autoptr(GFile) app_dir_data = NULL;
g_autoptr(GFile) app_dir_config = NULL;
g_autoptr(GFile) app_dir_cache = NULL;
+ g_autoptr(GFile) app_dir_state = NULL;
app_dir_data = g_file_get_child (app_dir, "data");
app_dir_config = g_file_get_child (app_dir, "config");
app_dir_cache = g_file_get_child (app_dir, "cache");
+ app_dir_state = g_file_get_child (app_dir, ".local/state");
flatpak_bwrap_set_env (bwrap, "XDG_DATA_HOME", flatpak_file_get_path_cached (app_dir_data), TRUE);
flatpak_bwrap_set_env (bwrap, "XDG_CONFIG_HOME", flatpak_file_get_path_cached (app_dir_config), TRUE);
flatpak_bwrap_set_env (bwrap, "XDG_CACHE_HOME", flatpak_file_get_path_cached (app_dir_cache), TRUE);
+ flatpak_bwrap_set_env (bwrap, "XDG_STATE_HOME", flatpak_file_get_path_cached (app_dir_state), TRUE);
if (g_getenv ("XDG_DATA_HOME"))
flatpak_bwrap_set_env (bwrap, "HOST_XDG_DATA_HOME", g_getenv ("XDG_DATA_HOME"), TRUE);
@@ -1856,6 +1859,8 @@ flatpak_run_apply_env_appid (FlatpakBwrap *bwrap,
flatpak_bwrap_set_env (bwrap, "HOST_XDG_CONFIG_HOME", g_getenv ("XDG_CONFIG_HOME"), TRUE);
if (g_getenv ("XDG_CACHE_HOME"))
flatpak_bwrap_set_env (bwrap, "HOST_XDG_CACHE_HOME", g_getenv ("XDG_CACHE_HOME"), TRUE);
+ if (g_getenv ("XDG_STATE_HOME"))
+ flatpak_bwrap_set_env (bwrap, "HOST_XDG_STATE_HOME", g_getenv ("XDG_STATE_HOME"), TRUE);
}
void
diff --git a/doc/flatpak-run.xml b/doc/flatpak-run.xml
index a9c2c947..87918252 100644
--- a/doc/flatpak-run.xml
+++ b/doc/flatpak-run.xml
@@ -98,6 +98,7 @@
<member>XDG_DATA_HOME</member>
<member>XDG_CONFIG_HOME</member>
<member>XDG_CACHE_HOME</member>
+ <member>XDG_STATE_HOME</member>
</simplelist>
<para>
The host values of these variables are made available inside the sandbox via these
@@ -107,6 +108,7 @@
<member>HOST_XDG_DATA_HOME</member>
<member>HOST_XDG_CONFIG_HOME</member>
<member>HOST_XDG_CACHE_HOME</member>
+ <member>HOST_XDG_STATE_HOME</member>
</simplelist>
<para>
Flatpak sets the environment variable <envar>FLATPAK_ID</envar> to the application
diff --git a/tests/libtest.sh b/tests/libtest.sh
index e12907f8..44f196b8 100644
--- a/tests/libtest.sh
+++ b/tests/libtest.sh
@@ -100,6 +100,7 @@ export HOME=${TEST_DATA_DIR}/home
export XDG_CACHE_HOME=${TEST_DATA_DIR}/home/cache
export XDG_CONFIG_HOME=${TEST_DATA_DIR}/home/config
export XDG_DATA_HOME=${TEST_DATA_DIR}/home/share
+export XDG_STATE_HOME=${TEST_DATA_DIR}/home/state
export XDG_RUNTIME_DIR=${TEST_DATA_DIR}/runtime
export XDG_DESKTOP_PORTAL_DIR=${test_builddir}/share/xdg-desktop-portal/portals
diff --git a/tests/testlib.c b/tests/testlib.c
index 28c97a4d..1e5d9428 100644
--- a/tests/testlib.c
+++ b/tests/testlib.c
@@ -44,6 +44,7 @@ isolated_test_dir_global_setup (void)
g_autofree char *cachedir = NULL;
g_autofree char *configdir = NULL;
g_autofree char *datadir = NULL;
+ g_autofree char *statedir = NULL;
g_autofree char *homedir = NULL;
g_autofree char *runtimedir = NULL;
@@ -72,6 +73,11 @@ isolated_test_dir_global_setup (void)
g_setenv ("XDG_DATA_HOME", datadir, TRUE);
g_test_message ("setting XDG_DATA_HOME=%s", datadir);
+ statedir = g_strconcat (isolated_test_dir, "/home/state", NULL);
+ g_assert_no_errno (g_mkdir_with_parents (statedir, S_IRWXU | S_IRWXG | S_IRWXO));
+ g_setenv ("XDG_STATE_HOME", statedir, TRUE);
+ g_test_message ("setting XDG_STATE_HOME=%s", statedir);
+
runtimedir = g_strconcat (isolated_test_dir, "/runtime", NULL);
g_assert_no_errno (g_mkdir_with_parents (runtimedir, S_IRWXU));
g_setenv ("XDG_RUNTIME_DIR", runtimedir, TRUE);
@@ -82,6 +88,7 @@ isolated_test_dir_global_setup (void)
g_assert_cmpstr (g_get_user_cache_dir (), ==, cachedir);
g_assert_cmpstr (g_get_user_config_dir (), ==, configdir);
g_assert_cmpstr (g_get_user_data_dir (), ==, datadir);
+ g_assert_cmpstr (g_getenv ("XDG_STATE_HOME"), ==, statedir);
g_assert_cmpstr (g_get_user_runtime_dir (), ==, runtimedir);
}
diff --git a/tests/testlibrary.c b/tests/testlibrary.c
index cac8a893..a52892db 100644
--- a/tests/testlibrary.c
+++ b/tests/testlibrary.c
@@ -2705,6 +2705,7 @@ global_setup (void)
g_autofree char *cachedir = NULL;
g_autofree char *configdir = NULL;
g_autofree char *datadir = NULL;
+ g_autofree char *statedir = NULL;
g_autofree char *homedir = NULL;
g_autofree char *services_dir = NULL;
@@ -2733,6 +2734,11 @@ global_setup (void)
g_setenv ("XDG_DATA_HOME", datadir, TRUE);
g_test_message ("setting XDG_DATA_HOME=%s", datadir);
+ statedir = g_strconcat (testdir, "/home/state", NULL);
+ g_mkdir_with_parents (statedir, S_IRWXU | S_IRWXG | S_IRWXO);
+ g_setenv ("XDG_STATE_HOME", statedir, TRUE);
+ g_test_message ("setting XDG_STATE_HOME=%s", statedir);
+
flatpak_runtimedir = g_strconcat (testdir, "/runtime", NULL);
g_mkdir_with_parents (flatpak_runtimedir, S_IRWXU | S_IRWXG | S_IRWXO);
g_setenv ("XDG_RUNTIME_DIR", flatpak_runtimedir, TRUE);