]> Sergey Matveev's repositories - public-inbox.git/commitdiff
imaptracker: use ~/.local/share/public-inbox/imap.sqlite3
authorEric Wong <e@yhbt.net>
Sat, 27 Jun 2020 10:03:30 +0000 (10:03 +0000)
committerEric Wong <e@yhbt.net>
Sun, 28 Jun 2020 22:27:09 +0000 (22:27 +0000)
Respect XDG_DATA_HOME to avoid cluttering ~/.public-inbox/.
Existing users of ~/.public-inbox/imap.sqlite3 will remain
supported, but the preference for new data is to use
~/.local/share and other paths standardized by XDG.

Cc: "Eric W. Biederman" <ebiederm@xmission.com>
MANIFEST
lib/PublicInbox/IMAPTracker.pm
t/imap_tracker.t [new file with mode: 0644]

index 42a00d7434425d7f346f5204f51dcc5ea72101c2..158d7ca2d8e50279e1133051565b127ee47e53e7 100644 (file)
--- a/MANIFEST
+++ b/MANIFEST
@@ -274,6 +274,7 @@ t/httpd.t
 t/hval.t
 t/imap.t
 t/imap_searchqp.t
+t/imap_tracker.t
 t/imapd-tls.t
 t/imapd.t
 t/import.t
index c7da422b725f0c9d8cab1c8bb3ccdb22aa7898c6..bb4a39cc41a64968b526a09d3f4fe4b972ba8ec0 100644 (file)
@@ -52,8 +52,23 @@ VALUES (?, ?, ?)
 }
 
 sub new {
-       my ($class) = @_;
-       my $dbname = PublicInbox::Config->config_dir() . "/imap.sqlite3";
+       my ($class, $dbname) = @_;
+
+       # original name for compatibility with old setups:
+       $dbname //= PublicInbox::Config->config_dir() . "/imap.sqlite3";
+
+       # use the new XDG-compliant name for new setups:
+       if (!-f $dbname) {
+               $dbname = ($ENV{XDG_DATA_HOME} //
+                       (($ENV{HOME} // '/nonexistent').'/.local/share')) .
+                       '/public-inbox/imap.sqlite3';
+       }
+       if (!-f $dbname) {
+               require File::Path;
+               require File::Basename;;
+               File::Path::mkpath(File::Basename::dirname($dbname));
+       }
+
        my $dbh = dbh_new($dbname);
        bless { dbname => $dbname, dbh => $dbh }, $class;
 }
diff --git a/t/imap_tracker.t b/t/imap_tracker.t
new file mode 100644 (file)
index 0000000..8dc04ed
--- /dev/null
@@ -0,0 +1,26 @@
+# Copyright (C) 2020 all contributors <meta@public-inbox.org>
+# License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
+use Test::More;
+use strict;
+use PublicInbox::TestCommon;
+require_mods 'DBD::SQLite';
+use_ok 'PublicInbox::IMAPTracker';
+my ($tmpdir, $for_destroy) = tmpdir();
+mkdir "$tmpdir/old" or die "mkdir $tmpdir/old: $!";
+my $old = "$tmpdir/old/imap.sqlite3";
+my $cur = "$tmpdir/data/public-inbox/imap.sqlite3";
+{
+       local $ENV{XDG_DATA_HOME} = "$tmpdir/data";
+       local $ENV{PI_DIR} = "$tmpdir/old";
+
+       my $tracker = PublicInbox::IMAPTracker->new;
+       ok(-f $cur, '->new creates file');
+       $tracker = undef;
+       ok(-f $cur, 'file persists after DESTROY');
+       link $cur, $old or die "link $cur => $old: $!";
+       unlink $cur or die "unlink $cur: $!";
+       $tracker = PublicInbox::IMAPTracker->new;
+       ok(!-f $cur, '->new does not create new file if old is present');
+}
+
+done_testing;