Compare commits

..

2 commits

Author SHA1 Message Date
Evie Litherland-Smith a6023abd2c Enable spotifyd service
Update ensure-pass section for spotify to allow spotifyd to use secret
service lookup
2024-10-16 07:58:49 +01:00
Evie Litherland-Smith 987cfbacae Combine different pass scripts into single ensure-pass.sh
Use password-store where possible to populate secret store without
user interaction (currently only Proton still needs manual input)

Add spotify to secret store ready for spotifyd
2024-10-16 07:52:52 +01:00
7 changed files with 63 additions and 36 deletions

View file

@ -1,8 +1,5 @@
{ config, pkgs, ... }: { config, pkgs, ... }:
{ {
home.packages = [
(pkgs.writeShellScriptBin "vdirsyncer-ensure-pass" (builtins.readFile ./vdirsyncer-ensure-pass.sh))
];
programs = { programs = {
vdirsyncer.enable = true; vdirsyncer.enable = true;
khal = { khal = {
@ -34,15 +31,21 @@
type = "filesystem"; type = "filesystem";
fileExt = ".ics"; fileExt = ".ics";
}; };
remote = { remote =
let
userName = "pixelifytica";
in
{
inherit userName;
url = "https://${url}"; url = "https://${url}";
type = "caldav"; type = "caldav";
userName = "pixelifytica";
passwordCommand = [ passwordCommand = [
"${pkgs.libsecret}/bin/secret-tool" "${pkgs.libsecret}/bin/secret-tool"
"lookup" "lookup"
"url" "url"
"${url}" "${url}"
"user"
"${userName}"
]; ];
}; };
vdirsyncer = { vdirsyncer = {

View file

@ -1,5 +0,0 @@
URL="dav.xenia.me.uk"
secret-tool lookup url "$URL" >/dev/null || (
echo "Setup calendar password"
secret-tool store --label="Personal calendar vdirsyncer" url "$URL"
)

View file

@ -19,7 +19,14 @@
]; ];
file.${config.gtk.gtk2.configLocation}.force = true; # Stop clashing with KDE file.${config.gtk.gtk2.configLocation}.force = true; # Stop clashing with KDE
}; };
services.syncthing.enable = true; services = {
syncthing.enable = true;
spotifyd = {
enable = true;
settings.global.username = "pixelifytica";
};
};
networking.firewall.allowedTCPPorts = [ 57621 ]; # Spotify Connect
gtk = { gtk = {
enable = true; enable = true;
gtk2.configLocation = "${config.xdg.configHome}/gtk-2.0/gtkrc"; gtk2.configLocation = "${config.xdg.configHome}/gtk-2.0/gtkrc";

View file

@ -1,7 +1,6 @@
{ config, pkgs, ... }: { config, pkgs, ... }:
{ {
home.packages = [ home.packages = [
(pkgs.writeShellScriptBin "mbsync-ensure-pass" (builtins.readFile ./mbsync-ensure-pass.sh))
(pkgs.writeShellScriptBin "davmail-setup" '' (pkgs.writeShellScriptBin "davmail-setup" ''
systemctl --user restart davmail # Ensure config file is present systemctl --user restart davmail # Ensure config file is present
systemctl --user stop davmail systemctl --user stop davmail

View file

@ -1,15 +0,0 @@
EMAIL_ADDRESSES=(
e.litherlandsmith@proton.me
e.litherlandsmith@icloud.com
evie.litherland-smith@ukaea.uk
)
LABELS=("Proton" "iCloud" "Outlook")
for i in "${!EMAIL_ADDRESSES[@]}"; do
ADDRESS="${EMAIL_ADDRESSES[$i]}"
LABEL="${LABELS[$i]}"
secret-tool lookup email "$ADDRESS" >/dev/null || (
echo "Setup $LABEL"
secret-tool store --label="$LABEL mail mbsync" email "$ADDRESS"
)
done

View file

@ -1,6 +1,7 @@
{ pkgs, ... }: { pkgs, ... }:
{ {
home.packages = [ home.packages = [
(pkgs.writeShellScriptBin "ensure-pass" (builtins.readFile ./shell/ensure-pass.sh))
(pkgs.writeShellScriptBin "esync" (builtins.readFile ./shell/esync.sh)) (pkgs.writeShellScriptBin "esync" (builtins.readFile ./shell/esync.sh))
(pkgs.writeShellScriptBin "clean-config" (builtins.readFile ./shell/clean-config.sh)) (pkgs.writeShellScriptBin "clean-config" (builtins.readFile ./shell/clean-config.sh))
(pkgs.writeShellScriptBin "rsync-local-config" (builtins.readFile ./shell/rsync-local-config.sh)) (pkgs.writeShellScriptBin "rsync-local-config" (builtins.readFile ./shell/rsync-local-config.sh))

View file

@ -0,0 +1,37 @@
# Email
ADDRESS="e.litherlandsmith@proton.me"
secret-tool lookup email "$ADDRESS" >/dev/null || (
echo "Insert pass from protonmail-bridge"
secret-tool store --label="Proton Mail mbsync" email "$ADDRESS"
)
ADDRESS="e.litherlandsmith@icloud.com"
secret-tool lookup email "$ADDRESS" >/dev/null || (
pass show identity/apple.com/mbsync |
head -n1 |
secret-tool store --label="iCloud mbsync" email "$ADDRESS"
)
ADDRESS="evie.litherland-smith@ukaea.uk"
secret-tool lookup email "$ADDRESS" >/dev/null || (
pass show work/microsoftonline.com |
head -n1 |
secret-tool store --label="Outlook mbsync" email "$ADDRESS"
)
# Calendar
URL="dav.xenia.me.uk"
USER="pixelifytica"
secret-tool lookup url "$URL" user "$USER" >/dev/null || (
pass show "server/xenia.me.uk/$URL" |
head -n1 |
secret-tool store --label="Personal calendar vdirsyncer" url "$URL" user "$USER"
)
# Spotify
# See https://docs.spotifyd.rs/config/File.html for attribute details
secret-tool lookup application rust-keyring service spotifyd username pixelifytica >/dev/null || (
pass show media/spotify.com |
head -n1 |
secret-tool store --label="Spotify" application rust-keyring service spotifyd username pixelifytica
)