Compare commits

..

No commits in common. "7c30c450e0dadf137e5273515b40c24b791433d1" and "5242deb1e8e94296c6b1a55043b6f922a8e828b2" have entirely different histories.

6 changed files with 241 additions and 59 deletions

View file

@ -26,7 +26,7 @@ with lib;
}; };
font = { font = {
name = "FiraCode Nerd Font Mono Reg"; name = "FiraCode Nerd Font Mono Reg";
package = pkgs.nerd-fonts.fira-code; package = with pkgs; (nerdfonts.override { fonts = [ "FiraCode" ]; });
}; };
themeFile = "Catppuccin-Mocha"; themeFile = "Catppuccin-Mocha";

View file

@ -57,6 +57,7 @@ import "${nixpkgs}/nixos/lib/eval-config.nix" {
codeberg-pages-custom = prev.pkgs.callPackage ../packages/codeberg-pages-custom { }; codeberg-pages-custom = prev.pkgs.callPackage ../packages/codeberg-pages-custom { };
readeck = prev.pkgs.callPackage ../packages/readeck { }; readeck = prev.pkgs.callPackage ../packages/readeck { };
uptime-kuma-beta = prev.pkgs.callPackage ../packages/uptime-kuma-beta { }; uptime-kuma-beta = prev.pkgs.callPackage ../packages/uptime-kuma-beta { };
isync = prev.pkgs.callPackage ../packages/isync { };
}) })
( (

View file

@ -1,4 +1,4 @@
{ pkgs, lib, ... }: { pkgs, ... }:
{ {
luj.hmgr.julien = { luj.hmgr.julien = {
@ -60,62 +60,60 @@
]; ];
}; };
home.packages = home.packages = with pkgs; [
with pkgs; du-dust
[ kitty
du-dust jq
kitty lazygit
jq fira-code
lazygit feh
fira-code meld
feh nerdfonts
meld jetbrains-mono
jetbrains-mono cantarell-fonts
cantarell-fonts unstable.nixd
unstable.nixd libreoffice
libreoffice signal-desktop
signal-desktop font-awesome
font-awesome nodejs
nodejs htop
htop evince
evince mosh
mosh flameshot
flameshot kitty
kitty networkmanagerapplet
networkmanagerapplet element-desktop
element-desktop xdg-utils
xdg-utils step-cli
step-cli scli
scli jftui
jftui texlive.combined.scheme-full
texlive.combined.scheme-full inochi-creator
inochi-creator inochi-session
inochi-session gh
gh ouch
ouch spotify
spotify nautilus
nautilus pika-backup
pika-backup mpv
mpv zotero
zotero emacsPackages.jinx
emacsPackages.jinx hunspellDicts.en_US
hunspellDicts.en_US rstudio
rstudio forge-sparks
forge-sparks citations
citations blanket
blanket fragments
fragments metadata-cleaner
metadata-cleaner gnome-obfuscate
gnome-obfuscate warp
warp tuba
tuba resources
resources notify-client
notify-client emacs-lsp-booster
emacs-lsp-booster pyright
pyright nixfmt-rfc-style
nixfmt-rfc-style ];
]
++ builtins.filter lib.attrsets.isDerivation (builtins.attrValues pkgs.nerd-fonts);
fonts.fontconfig.enable = true; fonts.fontconfig.enable = true;
@ -152,7 +150,6 @@
".config/dconf" ".config/dconf"
".local/share/keyrings" ".local/share/keyrings"
".cache/mu" ".cache/mu"
"Maildir"
]; ];
allowOther = true; allowOther = true;
}; };

View file

@ -0,0 +1,34 @@
From e8a3a20aed135272a9ec0103f4055411c075f043 Mon Sep 17 00:00:00 2001
From: Michal Sojka <michal.sojka@cvut.cz>
Date: Mon, 7 Nov 2022 00:07:22 +0100
Subject: [PATCH] Increase imap_vprintf buffer size
This fixes "Fatal: buffer too small. Please report a bug." error. See
https://sourceforge.net/p/isync/mailman/isync-devel/thread/87fsevvebj.fsf%40steelpick.2x.cz/#msg37731590
for related discussion.
When using mbsync with XOAUTH2 authentication (needed for Office365
mailboxes), the access token used for the LOGIN command may not fit
into the currently used buffer of 1000 characters. In my case, I need
the buffer to be at least 2000 characters long. To make this more
future-proof, I increase the buffer size to 4000 characters.
---
src/drv_imap.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/drv_imap.c b/src/drv_imap.c
index c5a7aed..7847192 100644
--- a/src/drv_imap.c
+++ b/src/drv_imap.c
@@ -528,7 +528,7 @@ imap_vprintf( const char *fmt, va_list ap )
uint totlen = 0;
const char *segs[MAX_SEGS];
uint segls[MAX_SEGS];
- char buf[1000];
+ char buf[4000];
d = buf;
ed = d + sizeof(buf);
--
2.38.1

View file

@ -0,0 +1,74 @@
{
lib,
stdenv,
fetchurl,
pkg-config,
perl,
openssl,
db,
cyrus_sasl,
zlib,
# Disabled by default as XOAUTH2 is an "OBSOLETE" SASL mechanism and this relies
# on a package that isn't really maintained anymore:
withCyrusSaslXoauth2 ? false,
cyrus-sasl-xoauth2,
makeWrapper,
}:
stdenv.mkDerivation rec {
pname = "isync";
version = "1.4.4";
src = fetchurl {
url = "mirror://sourceforge/isync/${pname}-${version}.tar.gz";
sha256 = "1zq0wwvmqsl9y71546dr0aygzn9gjjfiw19hlcq87s929y4p6ckw";
};
patches = [
# Fixes "Fatal: buffer too small" error
./0001-Increase-imap_vprintf-buffer-size.patch
# Fix #202595: SSL error "Socket error: ... unexpected eof while reading"
# Source: https://sourceforge.net/p/isync/isync/ci/b6c36624f04cd388873785c0631df3f2f9ac4bf0/
./work-around-unexpected-EOF-error-messages-at-end-of-SSL-connections.patch
];
nativeBuildInputs = [
pkg-config
perl
] ++ lib.optionals withCyrusSaslXoauth2 [ makeWrapper ];
buildInputs = [
openssl
db
cyrus_sasl
zlib
];
postInstall = lib.optionalString withCyrusSaslXoauth2 ''
wrapProgram "$out/bin/mbsync" \
--prefix SASL_PATH : "${
lib.makeSearchPath "lib/sasl2" [
cyrus-sasl-xoauth2
cyrus_sasl.out
]
}"
'';
meta = with lib; {
homepage = "http://isync.sourceforge.net/";
# https://sourceforge.net/projects/isync/
changelog = "https://sourceforge.net/p/isync/isync/ci/v${version}/tree/NEWS";
description = "Free IMAP and MailDir mailbox synchronizer";
longDescription = ''
mbsync (formerly isync) is a command line application which synchronizes
mailboxes. Currently Maildir and IMAP4 mailboxes are supported. New
messages, message deletions and flag changes can be propagated both ways.
'';
license = licenses.gpl2Plus;
platforms = platforms.unix;
maintainers = with maintainers; [
primeos
lheckemann
];
mainProgram = "mbsync";
};
}

View file

@ -0,0 +1,76 @@
From b6c36624f04cd388873785c0631df3f2f9ac4bf0 Mon Sep 17 00:00:00 2001
From: Oswald Buddenhagen <ossi@users.sf.net>
Date: Mon, 6 Jun 2022 11:55:37 +0200
Subject: [PATCH] work around "unexpected EOF" error messages at end of SSL
connections
gmail apparently doesn't send a close notification (SSL_shutdown())
before closing the TCP socket.
---
src/drv_imap.c | 7 +++++--
src/socket.c | 9 +++++++++
src/socket.h | 1 +
3 files changed, 15 insertions(+), 2 deletions(-)
diff --git a/src/drv_imap.c b/src/drv_imap.c
index fb8d165..6286045 100644
--- a/src/drv_imap.c
+++ b/src/drv_imap.c
@@ -1620,6 +1620,7 @@ imap_socket_read( void *aux )
error( "IMAP error: unexpected BYE response: %s\n", cmd );
/* We just wait for the server to close the connection now. */
ctx->expectEOF = 1;
+ socket_expect_eof( &ctx->conn );
} else {
/* We still need to wait for the LOGOUT's tagged OK. */
}
@@ -1882,10 +1883,12 @@ static void
imap_cleanup_p2( imap_store_t *ctx,
imap_cmd_t *cmd ATTR_UNUSED, int response )
{
- if (response == RESP_NO)
+ if (response == RESP_NO) {
imap_cancel_store( &ctx->gen );
- else if (response == RESP_OK)
+ } else if (response == RESP_OK) {
ctx->expectEOF = 1;
+ socket_expect_eof( &ctx->conn );
+ }
}
/******************* imap_open_store *******************/
diff --git a/src/socket.c b/src/socket.c
index ac3c847..892cece 100644
--- a/src/socket.c
+++ b/src/socket.c
@@ -810,6 +810,15 @@ socket_expect_activity( conn_t *conn, int expect )
conf_wakeup( &conn->fd_timeout, expect ? conn->conf->timeout : -1 );
}
+void
+socket_expect_eof( conn_t *sock )
+{
+#ifdef SSL_OP_IGNORE_UNEXPECTED_EOF // implies HAVE_LIBSSL
+ if (sock->ssl)
+ SSL_set_options( sock->ssl, SSL_OP_IGNORE_UNEXPECTED_EOF );
+#endif
+}
+
int
socket_read( conn_t *conn, char *buf, uint len )
{
diff --git a/src/socket.h b/src/socket.h
index 5b1edd0..af679aa 100644
--- a/src/socket.h
+++ b/src/socket.h
@@ -142,6 +142,7 @@ void socket_start_tls(conn_t *conn, void (*cb)( int ok, void *aux ) );
void socket_start_deflate( conn_t *conn );
void socket_close( conn_t *sock );
void socket_expect_activity( conn_t *sock, int expect );
+void socket_expect_eof( conn_t *sock );
int socket_read( conn_t *sock, char *buf, uint len ); /* never waits */
char *socket_read_line( conn_t *sock ); /* don't free return value; never waits */
typedef enum { KeepOwn = 0, GiveOwn } ownership_t;
--
2.38.0