update
This commit is contained in:
@@ -17,6 +17,7 @@
|
||||
./modules/laptop/default.nix
|
||||
./modules/laptop/fingerprint.nix
|
||||
./modules/laptop/users.nix
|
||||
./modules/laptop/home-manager.nix
|
||||
./modules/laptop/bluetooth.nix
|
||||
./modules/laptop/zwift.nix
|
||||
|
||||
|
||||
0
dotconfig/.gitkeep
Normal file
0
dotconfig/.gitkeep
Normal file
2
dotconfig/alacritty/alacritty.toml
Normal file
2
dotconfig/alacritty/alacritty.toml
Normal file
@@ -0,0 +1,2 @@
|
||||
[font]
|
||||
normal = { family = "DejaVuSansM Nerd Font Mono", style = "Regular"}
|
||||
7
dotconfig/i3/autostart.sh
Executable file
7
dotconfig/i3/autostart.sh
Executable file
@@ -0,0 +1,7 @@
|
||||
#!/bin/bash
|
||||
sleep 1
|
||||
|
||||
i3 gaps inner current set 10
|
||||
i3 gaps outer current set 0
|
||||
|
||||
sleep 1
|
||||
234
dotconfig/i3/config
Normal file
234
dotconfig/i3/config
Normal file
@@ -0,0 +1,234 @@
|
||||
# This file has been auto-generated by i3-config-wizard(1).
|
||||
# It will not be overwritten, so edit it as you like.
|
||||
#
|
||||
# Should you change your keyboard layout some time, delete
|
||||
# this file and re-run i3-config-wizard(1).
|
||||
#
|
||||
|
||||
# i3 config file (v4)
|
||||
#
|
||||
# Please see https://i3wm.org/docs/userguide.html for a complete reference!
|
||||
|
||||
gaps inner 10
|
||||
gaps outer 12
|
||||
default_border pixel 0
|
||||
default_floating_border pixel 0
|
||||
|
||||
set $mod Mod4
|
||||
|
||||
# Font for window titles. Will also be used by the bar unless a different font
|
||||
# is used in the bar {} block below.
|
||||
font pango:monospace 8
|
||||
|
||||
# https://thomashunter.name/i3-configurator/
|
||||
# class border bground text indicator child_border
|
||||
client.focused #2F4A36 #2F4A36 #FFFFFF #2F4A36 #2F4A36
|
||||
client.focused_inactive #52805E #52805E #FFFFFF #484E50 #5F676A
|
||||
client.unfocused #0A100B #0A100B #888888 #292D2E #222222
|
||||
client.urgent #2F343A #900000 #FFFFFF #900000 #900000
|
||||
client.placeholder #000000 #0C0C0C #FFFFFF #000000 #0C0C0C
|
||||
|
||||
client.background #FFFFFF
|
||||
|
||||
# This font is widely installed, provides lots of unicode glyphs, right-to-left
|
||||
# text rendering and scalability on retina/hidpi displays (thanks to pango).
|
||||
#font pango:DejaVu Sans Mono 8
|
||||
|
||||
# Start XDG autostart .desktop files using dex. See also
|
||||
# https://wiki.archlinux.org/index.php/XDG_Autostart
|
||||
exec --no-startup-id dex --autostart --environment i3
|
||||
|
||||
# The combination of xss-lock, nm-applet and pactl is a popular choice, so
|
||||
# they are included here as an example. Modify as you see fit.
|
||||
|
||||
# xss-lock grabs a logind suspend inhibit lock and will use i3lock to lock the
|
||||
# screen before suspend. Use loginctl lock-session to lock your screen.
|
||||
exec --no-startup-id xss-lock --transfer-sleep-lock -- i3lock --nofork
|
||||
|
||||
# NetworkManager is the most popular way to manage wireless networks on Linux,
|
||||
# and nm-applet is a desktop environment-independent system tray GUI for it.
|
||||
# exec --no-startup-id nm-applet
|
||||
|
||||
# Use pactl to adjust volume in PulseAudio.
|
||||
set $refresh_i3status killall -SIGUSR1 i3status
|
||||
bindsym XF86AudioRaiseVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ +10% && $refresh_i3status
|
||||
bindsym XF86AudioLowerVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ -10% && $refresh_i3status
|
||||
bindsym XF86AudioMute exec --no-startup-id pactl set-sink-mute @DEFAULT_SINK@ toggle && $refresh_i3status
|
||||
bindsym XF86AudioMicMute exec --no-startup-id pactl set-source-mute @DEFAULT_SOURCE@ toggle && $refresh_i3status
|
||||
|
||||
# Use Mouse+$mod to drag floating windows to their wanted position
|
||||
floating_modifier $mod
|
||||
|
||||
# start a terminal
|
||||
# bindsym $mod+Return exec i3-sensible-terminal
|
||||
|
||||
# kill focused window
|
||||
bindsym $mod+Shift+Q kill
|
||||
|
||||
# start dmenu (a program launcher)
|
||||
bindsym $mod+d exec --no-startup-id rofi -show drun -show-icons
|
||||
# A more modern dmenu replacement is rofi:
|
||||
# bindcode $mod+40 exec "rofi -modi drun,run -show drun"
|
||||
# There also is i3-dmenu-desktop which only displays applications shipping a
|
||||
# .desktop file. It is a wrapper around dmenu, so you need that installed.
|
||||
# bindcode $mod+40 exec --no-startup-id i3-dmenu-desktop
|
||||
|
||||
# change focus
|
||||
# bindsym $mod+j focus left
|
||||
# bindsym $mod+k focus down
|
||||
# bindsym $mod+l focus up
|
||||
# bindsym $mod+m focus right
|
||||
|
||||
# alternatively, you can use the cursor keys:
|
||||
bindsym $mod+Left focus left
|
||||
bindsym $mod+Down focus down
|
||||
bindsym $mod+Up focus up
|
||||
bindsym $mod+Right focus right
|
||||
|
||||
# move focused window
|
||||
# bindsym $mod+Shift+j move left
|
||||
# bindsym $mod+Shift+k move down
|
||||
# bindsym $mod+Shift+l move up
|
||||
# bindsym $mod+Shift+M move right
|
||||
|
||||
# alternatively, you can use the cursor keys:
|
||||
bindsym $mod+Shift+Left move left
|
||||
bindsym $mod+Shift+Down move down
|
||||
bindsym $mod+Shift+Up move up
|
||||
bindsym $mod+Shift+Right move right
|
||||
|
||||
# split in horizontal orientation
|
||||
bindsym $mod+h split h
|
||||
|
||||
# split in vertical orientation
|
||||
bindsym $mod+v split v
|
||||
|
||||
# enter fullscreen mode for the focused container
|
||||
bindsym $mod+f fullscreen toggle
|
||||
|
||||
# change container layout (stacked, tabbed, toggle split)
|
||||
bindsym $mod+s layout stacking
|
||||
bindsym $mod+z layout tabbed
|
||||
bindsym $mod+e layout toggle split
|
||||
|
||||
# toggle tiling / floating
|
||||
bindsym $mod+Shift+space floating toggle
|
||||
|
||||
# change focus between tiling / floating windows
|
||||
bindsym $mod+space focus mode_toggle
|
||||
|
||||
# focus the parent container
|
||||
bindsym $mod+q focus parent
|
||||
|
||||
# focus the child container
|
||||
#bindsym $mod+d focus child
|
||||
|
||||
# Define names for default workspaces for which we configure key bindings later on.
|
||||
# We use variables to avoid repeating the names in multiple places.
|
||||
set $ws1 "1"
|
||||
set $ws2 "2"
|
||||
set $ws3 "3"
|
||||
set $ws4 "4"
|
||||
set $ws5 "5"
|
||||
set $ws6 "6"
|
||||
set $ws7 "7"
|
||||
set $ws8 "8"
|
||||
set $ws9 "9"
|
||||
set $ws10 "10"
|
||||
|
||||
# switch to workspace
|
||||
bindsym $mod+ampersand workspace number $ws1
|
||||
bindsym $mod+eacute workspace number $ws2
|
||||
bindsym $mod+quotedbl workspace number $ws3
|
||||
bindsym $mod+apostrophe workspace number $ws4
|
||||
bindsym $mod+parenleft workspace number $ws5
|
||||
bindsym $mod+minus workspace number $ws6
|
||||
bindsym $mod+egrave workspace number $ws7
|
||||
bindsym $mod+underscore workspace number $ws8
|
||||
bindsym $mod+ccedilla workspace number $ws9
|
||||
bindsym $mod+agrave workspace number $ws10
|
||||
|
||||
# move focused container to workspace
|
||||
bindsym $mod+Shift+1 move container to workspace number $ws1
|
||||
bindsym $mod+Shift+eacute move container to workspace number $ws2
|
||||
bindsym $mod+Shift+3 move container to workspace number $ws3
|
||||
bindsym $mod+Shift+4 move container to workspace number $ws4
|
||||
bindsym $mod+Shift+5 move container to workspace number $ws5
|
||||
bindsym $mod+Shift+6 move container to workspace number $ws6
|
||||
bindsym $mod+Shift+egrave move container to workspace number $ws7
|
||||
bindsym $mod+Shift+8 move container to workspace number $ws8
|
||||
bindsym $mod+Shift+ccedilla move container to workspace number $ws9
|
||||
bindsym $mod+Shift+agrave move container to workspace number $ws10
|
||||
|
||||
# reload the configuration file
|
||||
bindsym $mod+Shift+c reload
|
||||
# restart i3 inplace (preserves your layout/session, can be used to upgrade i3)
|
||||
bindsym $mod+Shift+r restart
|
||||
# exit i3 (logs you out of your X session)
|
||||
bindsym $mod+Shift+e exec "i3-nagbar -t warning -m 'You pressed the exit shortcut. Do you really want to exit i3? This will end your X session.' -B 'Yes, exit i3' 'i3-msg exit'"
|
||||
|
||||
# resize window (you can also use the mouse for that)
|
||||
mode "resize" {
|
||||
# These bindings trigger as soon as you enter the resize mode
|
||||
|
||||
# Pressing left will shrink the window’s width.
|
||||
# Pressing right will grow the window’s width.
|
||||
# Pressing up will shrink the window’s height.
|
||||
# Pressing down will grow the window’s height.
|
||||
# bindsym j resize shrink width 10 px or 10 ppt
|
||||
# bindsym k resize grow height 10 px or 10 ppt
|
||||
# bindsym l resize shrink height 10 px or 10 ppt
|
||||
# bindsym m resize grow width 10 px or 10 ppt
|
||||
|
||||
# same bindings, but for the arrow keys
|
||||
bindsym Left resize shrink width 10 px or 10 ppt
|
||||
bindsym Down resize grow height 10 px or 10 ppt
|
||||
bindsym Up resize shrink height 10 px or 10 ppt
|
||||
bindsym Right resize grow width 10 px or 10 ppt
|
||||
|
||||
# back to normal: Enter or Escape or $mod+r
|
||||
bindsym Return mode "default"
|
||||
bindsym Escape mode "default"
|
||||
bindsym $mod+r mode "default"
|
||||
}
|
||||
|
||||
bindsym $mod+r mode "resize"
|
||||
|
||||
# Start i3bar to display a workspace bar (plus the system information i3status
|
||||
# finds out, if available)
|
||||
# bar {
|
||||
# status_command /home/alice/.config/polybar/start.sh
|
||||
# }
|
||||
# exec --no-startup-id tint2
|
||||
|
||||
# custom
|
||||
exec_always --no-startup-id /home/alice/.config/i3/autostart.sh
|
||||
exec_always --no-startup-id /home/alice/.config/polybar/start.sh
|
||||
exec_always --no-startup-id picom
|
||||
# exec_always --no-startup-id eww open frame
|
||||
# exec_alwaysé --no-startup-id betterlockscreen -u /home/alice/.config/betterlockscreen -u /home/alice/wallpaper/ -l dimb
|
||||
|
||||
bindsym $mod+Shift+l exec --no-startup-id i3lock -c 000000
|
||||
|
||||
bindsym $mod+Return exec alacritty
|
||||
|
||||
bindsym $mod+Tab exec rofi -show combi -show-icons
|
||||
|
||||
bindsym $mod+p move workspace to output left
|
||||
|
||||
# bindsym $mod+m exec autorandr right_h
|
||||
# bindsym $mod+Shift+m exec autorandr right_v
|
||||
# bindsym $mod+k exec autorandr left_h
|
||||
# bindsym $mod+Shift+k exec autorandr left_v
|
||||
# bindsym $mod+l exec autorandr laptop
|
||||
# bindsym $mod+o exec autorandr duplicate
|
||||
|
||||
## Screenshots
|
||||
# bindsym Print exec --no-startup-id maim "/home/$USER/Pictures/$(date)"
|
||||
# bindsym $mod+Print exec --no-startup-id maim --window $(xdotool getactivewindow) "/home/$USER/Pictures/$(date)"
|
||||
# bindsym Shift+Print exec --no-startup-id maim --select "/home/$USER/Pictures/$(date)"
|
||||
|
||||
## Clipboard Screenshots
|
||||
# bindsym Ctrl+Print exec --no-startup-id maim | xclip -selection clipboard -t image/png
|
||||
# bindsym Ctrl+$mod+Print exec --no-startup-id maim --window $(xdotool getactivewindow) | xclip -selection clipboard -t image/png
|
||||
bindsym $mod+Shift+Print exec --no-startup-id maim --select | xclip -selection clipboard -t image/png
|
||||
40
dotconfig/picom/picom.conf
Normal file
40
dotconfig/picom/picom.conf
Normal file
@@ -0,0 +1,40 @@
|
||||
# Picom configuration file
|
||||
|
||||
# Backend
|
||||
backend = "glx";
|
||||
vsync = true;
|
||||
use-damage = true;
|
||||
|
||||
# Shadows
|
||||
shadow = true;
|
||||
shadow-radius = 10;
|
||||
shadow-offset-x = -5;
|
||||
shadow-offset-y = -5;
|
||||
shadow-opacity = 0.8;
|
||||
|
||||
# Opacity
|
||||
frame-opacity = 1.0;
|
||||
|
||||
# Fading
|
||||
fading = true;
|
||||
fade-in-step = 0.03;
|
||||
fade-out-step = 0.03;
|
||||
fade-delta = 10;
|
||||
|
||||
corner-radius = 20;
|
||||
|
||||
# regles par application
|
||||
rules: ({
|
||||
match = "class_g = 'Alacritty'";
|
||||
opacity = 0.8;
|
||||
}, {
|
||||
match = "class_g = 'i3-frame'";
|
||||
corner-radius = 0;
|
||||
} , {
|
||||
match = "class_g = 'Polybar'";
|
||||
corner-radius = 0;
|
||||
} , {
|
||||
match = "class_g = 'Eww'";
|
||||
corner-radius = 0;
|
||||
}
|
||||
);
|
||||
257
dotconfig/polybar/config.ini.model
Normal file
257
dotconfig/polybar/config.ini.model
Normal file
@@ -0,0 +1,257 @@
|
||||
[color]
|
||||
background = #2f4a36
|
||||
background-alt = #375740
|
||||
foreground = #e8e8e8
|
||||
foreground-dim = #b8c0b8
|
||||
accent = #a3be8c
|
||||
alert = #ff6b6b
|
||||
|
||||
; =========================
|
||||
; BASES
|
||||
; =========================
|
||||
|
||||
[bar/base]
|
||||
monitor = ${env:MONITOR:}
|
||||
width = 100%
|
||||
height = 20
|
||||
offset-x = 0
|
||||
foreground = ${color.foreground}
|
||||
border-size = 0
|
||||
line-size = 0
|
||||
padding-left = 1
|
||||
padding-right = 1
|
||||
module-margin = 1
|
||||
separator = " · "
|
||||
separator-foreground = ${color.foreground-dim}
|
||||
font-0 = "DejaVuSansM Nerd Font Mono:size=10;2"
|
||||
font-1 = "Noto Sans CJK JP:size=10;2"
|
||||
font-2 = "Noto Color Emoji:size=10;2"
|
||||
radius = 10
|
||||
enable-ipc = true
|
||||
|
||||
[module/temp-base]
|
||||
type = internal/temperature
|
||||
warn-temperature = 80
|
||||
format = <label>
|
||||
label-warn-foreground = ${color.alert}
|
||||
|
||||
[fs-base]
|
||||
type = internal/fs
|
||||
interval = 30
|
||||
fixed-values = true
|
||||
format-mounted = <label-mounted>
|
||||
|
||||
; =========================
|
||||
; BARS
|
||||
; =========================
|
||||
|
||||
[bar/top]
|
||||
inherit = bar/base
|
||||
offset-y = 0
|
||||
background = ${color.background}
|
||||
modules-left =
|
||||
modules-center = date-time
|
||||
modules-right = battery
|
||||
radius-bottom = 0
|
||||
|
||||
[bar/middle]
|
||||
inherit = bar/base
|
||||
offset-y = 20
|
||||
background = ${color.background-alt}
|
||||
modules-left = cpu memory
|
||||
modules-center = cpu-temp gpu-temp nvme-temp fan
|
||||
modules-right = dns
|
||||
radius = 0
|
||||
|
||||
[bar/bottom]
|
||||
inherit = bar/base
|
||||
offset-y = 40
|
||||
background = ${color.background}
|
||||
modules-left = net-wireless
|
||||
modules-center = fs-system
|
||||
modules-right = volume
|
||||
radius-top = 0
|
||||
|
||||
; =========================
|
||||
; FOOTER
|
||||
; =========================
|
||||
|
||||
[bar/tray-bottom]
|
||||
inherit = bar/base
|
||||
bottom = true
|
||||
offset-y = 0
|
||||
background = ${color.background-alt}
|
||||
modules-left = desktops
|
||||
modules-center = ping-amaury
|
||||
modules-right = spotify spotify-prev spotify-play-pause spotify-next tray
|
||||
|
||||
[bar/bottom-b]
|
||||
inherit = bar/base
|
||||
bottom = true
|
||||
offset-y = 0
|
||||
background = ${color.background-alt}
|
||||
modules-left = desktops
|
||||
modules-center =
|
||||
modules-right =
|
||||
|
||||
|
||||
; =========================
|
||||
; MODULES
|
||||
; =========================
|
||||
|
||||
[module/desktops]
|
||||
type = internal/i3
|
||||
pin-workspaces = true
|
||||
enable-click = true
|
||||
enable-scroll = true
|
||||
scroll-up = "#i3.prev"
|
||||
scroll-down = "#i3.next"
|
||||
|
||||
label-focused = %name%
|
||||
label-focused-padding = 1
|
||||
label-focused-background = ${color.accent}
|
||||
label-focused-foreground = #1f2a1f
|
||||
|
||||
label-unfocused = %name%
|
||||
label-unfocused-padding = 1
|
||||
label-unfocused-foreground = ${color.foreground-dim}
|
||||
|
||||
label-visible = %name%
|
||||
label-visible-padding = 1
|
||||
|
||||
label-urgent = %name%
|
||||
label-urgent-padding = 1
|
||||
label-urgent-background = ${color.alert}
|
||||
label-urgent-foreground = #ffffff
|
||||
|
||||
[module/cpu]
|
||||
type = internal/cpu
|
||||
interval = 2
|
||||
format = <label>
|
||||
label = CPU %percentage%%
|
||||
|
||||
[module/memory]
|
||||
type = internal/memory
|
||||
interval = 2
|
||||
format = <label>
|
||||
label = RAM %percentage_used%% %used%
|
||||
|
||||
[module/cpu-temp]
|
||||
inherit = module/temp-base
|
||||
hwmon-path = /sys/devices/platform/thinkpad_hwmon/hwmon/hwmon@HW@/temp1_input
|
||||
label = CPU %temperature-c%
|
||||
label-warn = CPU %temperature-c%
|
||||
|
||||
[module/gpu-temp]
|
||||
inherit = module/temp-base
|
||||
hwmon-path = /sys/devices/platform/thinkpad_hwmon/hwmon/hwmon@HW@/temp2_input
|
||||
label = GPU %temperature-c%
|
||||
label-warn = GPU %temperature-c%
|
||||
|
||||
[module/nvme-temp]
|
||||
inherit = module/temp-base
|
||||
hwmon-path = /sys/devices/pci0000:00/0000:00:06.0/0000:01:00.0/nvme/nvme0/hwmon0/temp1_input
|
||||
label = NVMe %temperature-c%
|
||||
label-warn = NVMe %temperature-c%
|
||||
|
||||
[module/fan]
|
||||
type = custom/script
|
||||
exec = cat /sys/devices/platform/thinkpad_hwmon/hwmon/hwmon*/fan1_input
|
||||
label = Fan %output% RPM
|
||||
|
||||
[module/date-time]
|
||||
type = internal/date
|
||||
interval = 1
|
||||
date = %a %d %b
|
||||
time = %H:%M:%S
|
||||
label = %date% · %time%
|
||||
|
||||
[module/battery]
|
||||
type = internal/battery
|
||||
battery = BAT0
|
||||
adapter = AC
|
||||
poll-interval = 1
|
||||
low-at = 15
|
||||
full-at = 100
|
||||
time-format = %Hh %Mm
|
||||
|
||||
format-charging = <label-charging>
|
||||
label-charging = %percentage%% %time% %consumption%W
|
||||
|
||||
format-discharging = <label-discharging>
|
||||
label-discharging = %percentage%% %time% %consumption%W
|
||||
|
||||
format-full = <label-full>
|
||||
label-full = %percentage%%
|
||||
|
||||
format-low = <label-low>
|
||||
label-low = %percentage%%
|
||||
label-low-foreground = ${color.alert}
|
||||
|
||||
[module/net-wireless]
|
||||
type = internal/network
|
||||
interface-type = wireless
|
||||
interval = 3
|
||||
speed-unit = B/s
|
||||
format-connected = <label-connected>
|
||||
label-connected = %essid% · %local_ip% · U %upspeed% · D %downspeed%
|
||||
format-disconnected = <label-disconnected>
|
||||
label-disconnected = Wi-Fi down
|
||||
label-disconnected-foreground = ${color.foreground-dim}
|
||||
|
||||
[module/fs-system]
|
||||
inherit = fs-base
|
||||
mount-0 = /
|
||||
label-mounted = / %used% on %total%
|
||||
|
||||
[module/dns]
|
||||
type = custom/script
|
||||
exec = nslookup amauryjoly.fr | sed -n '2p' | awk '{print $2}'
|
||||
interval = 30
|
||||
label = DNS %output%
|
||||
|
||||
[module/volume]
|
||||
type = internal/pulseaudio
|
||||
format-volume = <label-volume>
|
||||
label-volume = VOL %percentage%%
|
||||
format-muted = <label-muted>
|
||||
label-muted = VOL mute
|
||||
label-muted-foreground = ${color.foreground-dim}
|
||||
|
||||
[module/tray]
|
||||
type = internal/tray
|
||||
format-margin = 2
|
||||
tray-spacing = 0
|
||||
|
||||
[module/ping-amaury]
|
||||
type = custom/script
|
||||
exec = sh -c 'v=$(ping -c 1 -W 1 amauryjoly.fr 2>/dev/null | sed -n "s/.*temps=\\([0-9.]*\\).*/\\1/p"); [ -n "$v" ] && echo "$v ms" || echo "down"'
|
||||
interval = 60
|
||||
format = <label>
|
||||
label = LAT %output%
|
||||
|
||||
[module/spotify]
|
||||
type = custom/script
|
||||
tail = true
|
||||
interval = 5
|
||||
; prefix symbol is shown before the text
|
||||
format-prefix = " "
|
||||
format = <label>
|
||||
exec = ~/.config/polybar/scroll_spotify_status.sh
|
||||
|
||||
[module/spotify-prev]
|
||||
type = custom/text
|
||||
format = ""
|
||||
click-left = playerctl previous -p spotify
|
||||
|
||||
[module/spotify-play-pause]
|
||||
type = custom/ipc
|
||||
hook-0 = echo ''
|
||||
hook-1 = echo ''
|
||||
initial = 1
|
||||
click-left = playerctl play-pause -p spotify
|
||||
|
||||
[module/spotify-next]
|
||||
type = custom/text
|
||||
format = ""
|
||||
click-left = playerctl next -p spotify
|
||||
51
dotconfig/polybar/get_spotify_status.sh
Executable file
51
dotconfig/polybar/get_spotify_status.sh
Executable file
@@ -0,0 +1,51 @@
|
||||
#!/bin/sh
|
||||
# https://github.com/PrayagS/polybar-spotify/blob/master/get_spotify_status.sh
|
||||
|
||||
# The name of polybar bar which houses the main spotify module and the control modules.
|
||||
PARENT_BAR="tray-bottom"
|
||||
PARENT_BAR_PID=$(pgrep -a "polybar" | grep "$PARENT_BAR" | cut -d" " -f1)
|
||||
|
||||
# Set the source audio player here.
|
||||
# Players supporting the MPRIS spec are supported.
|
||||
# Examples: spotify, vlc, chrome, mpv and others.
|
||||
# Use `playerctld` to always detect the latest player.
|
||||
# See more here: https://github.com/altdesktop/playerctl/#selecting-players-to-control
|
||||
PLAYER="spotify"
|
||||
|
||||
# Format of the information displayed
|
||||
# Eg. {{ artist }} - {{ album }} - {{ title }}
|
||||
# See more attributes here: https://github.com/altdesktop/playerctl/#printing-properties-and-metadata
|
||||
FORMAT="{{ title }} - {{ artist }}"
|
||||
|
||||
# Sends $2 as message to all polybar PIDs that are part of $1
|
||||
update_hooks() {
|
||||
while IFS= read -r id
|
||||
do
|
||||
polybar-msg -p "$id" hook spotify-play-pause $2 1>/dev/null 2>&1
|
||||
done < <(echo "$1")
|
||||
}
|
||||
|
||||
PLAYERCTL_STATUS=$(playerctl --player=$PLAYER status 2>/dev/null)
|
||||
EXIT_CODE=$?
|
||||
|
||||
if [ $EXIT_CODE -eq 0 ]; then
|
||||
STATUS=$PLAYERCTL_STATUS
|
||||
else
|
||||
STATUS="No player is running"
|
||||
fi
|
||||
|
||||
if [ "$1" == "--status" ]; then
|
||||
echo "$STATUS"
|
||||
else
|
||||
if [ "$STATUS" = "Stopped" ]; then
|
||||
echo "No music is playing"
|
||||
elif [ "$STATUS" = "Paused" ]; then
|
||||
update_hooks "$PARENT_BAR_PID" 2
|
||||
playerctl --player=$PLAYER metadata --format "$FORMAT"
|
||||
elif [ "$STATUS" = "No player is running" ]; then
|
||||
echo "$STATUS"
|
||||
else
|
||||
update_hooks "$PARENT_BAR_PID" 1
|
||||
playerctl --player=$PLAYER metadata --format "$FORMAT"
|
||||
fi
|
||||
fi
|
||||
12
dotconfig/polybar/scroll_spotify_status.sh
Executable file
12
dotconfig/polybar/scroll_spotify_status.sh
Executable file
@@ -0,0 +1,12 @@
|
||||
#!/bin/sh
|
||||
|
||||
# see man zscroll for documentation of the following parameters
|
||||
zscroll -l 30 \
|
||||
--delay 1 \
|
||||
--scroll-padding " " \
|
||||
--match-command "`dirname $0`/get_spotify_status.sh --status" \
|
||||
--match-text "Playing" "--scroll 1" \
|
||||
--match-text "Paused" "--scroll 0" \
|
||||
--update-check true "`dirname $0`/get_spotify_status.sh" &
|
||||
|
||||
wait
|
||||
40
dotconfig/polybar/start.sh
Executable file
40
dotconfig/polybar/start.sh
Executable file
@@ -0,0 +1,40 @@
|
||||
#!/bin/sh
|
||||
|
||||
killall -q polybar
|
||||
|
||||
while pgrep -x polybar >/dev/null; do
|
||||
sleep 1
|
||||
done
|
||||
|
||||
hw=""
|
||||
for h in /sys/class/hwmon/hwmon*; do
|
||||
if grep -qx 'thinkpad' "$h/name"; then
|
||||
hw=${h##*/hwmon}
|
||||
break
|
||||
fi
|
||||
done
|
||||
|
||||
[ -n "$hw" ] || {
|
||||
echo "Capteur thinkpad introuvable" >&2
|
||||
exit 1
|
||||
}
|
||||
|
||||
polybar_dir="/home/alice/.config/polybar"
|
||||
|
||||
tmpconf="$polybar_dir/config.ini"
|
||||
sed "s/@HW@/$hw/g" $polybar_dir/config.ini.model > "$tmpconf"
|
||||
|
||||
primary=$(xrandr --query | grep " primary" | cut -d" " -f1)
|
||||
|
||||
for m in $(xrandr --query | grep " connected" | cut -d" " -f1); do
|
||||
MONITOR="$m" HW="$hw" polybar top &
|
||||
sleep 0.1
|
||||
MONITOR="$m" HW="$hw" polybar middle &
|
||||
sleep 0.1
|
||||
MONITOR="$m" HW="$hw" polybar bottom &
|
||||
if [ "$m" = "$primary" ]; then
|
||||
MONITOR="$m" HW="$hw" polybar tray-bottom &
|
||||
else
|
||||
MONITOR="$m" HW="$hw" polybar bottom-b &
|
||||
fi
|
||||
done
|
||||
57
flake.lock
generated
57
flake.lock
generated
@@ -32,11 +32,11 @@
|
||||
"rust-analyzer-src": "rust-analyzer-src"
|
||||
},
|
||||
"locked": {
|
||||
"lastModified": 1773040819,
|
||||
"narHash": "sha256-9sFursJ9PJoYQFyARzQEKcv5D5SaGU3xJtZDSqEMtek=",
|
||||
"lastModified": 1773646590,
|
||||
"narHash": "sha256-qwnecNC3DB0hSu6MvU27xh/Mg9uPbmmg7d1wBOtO7ds=",
|
||||
"owner": "nix-community",
|
||||
"repo": "fenix",
|
||||
"rev": "6ed2afab20d32920f0984e619ff5f58b2b5d2948",
|
||||
"rev": "350a4df2afc34c1ae115173e0509cec7067a06c9",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
@@ -81,6 +81,26 @@
|
||||
"type": "github"
|
||||
}
|
||||
},
|
||||
"home-manager": {
|
||||
"inputs": {
|
||||
"nixpkgs": [
|
||||
"nixpkgs"
|
||||
]
|
||||
},
|
||||
"locked": {
|
||||
"lastModified": 1774007980,
|
||||
"narHash": "sha256-FOnZjElEI8pqqCvB6K/1JRHTE8o4rer8driivTpq2uo=",
|
||||
"owner": "nix-community",
|
||||
"repo": "home-manager",
|
||||
"rev": "9670de2921812bc4e0452f6e3efd8c859696c183",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
"owner": "nix-community",
|
||||
"repo": "home-manager",
|
||||
"type": "github"
|
||||
}
|
||||
},
|
||||
"nix-github-actions": {
|
||||
"inputs": {
|
||||
"nixpkgs": [
|
||||
@@ -105,11 +125,11 @@
|
||||
},
|
||||
"nixpkgs": {
|
||||
"locked": {
|
||||
"lastModified": 1772963539,
|
||||
"narHash": "sha256-9jVDGZnvCckTGdYT53d/EfznygLskyLQXYwJLKMPsZs=",
|
||||
"lastModified": 1773821835,
|
||||
"narHash": "sha256-TJ3lSQtW0E2JrznGVm8hOQGVpXjJyXY2guAxku2O9A4=",
|
||||
"owner": "NixOS",
|
||||
"repo": "nixpkgs",
|
||||
"rev": "9dcb002ca1690658be4a04645215baea8b95f31d",
|
||||
"rev": "b40629efe5d6ec48dd1efba650c797ddbd39ace0",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
@@ -144,11 +164,11 @@
|
||||
"poetry2nix": "poetry2nix"
|
||||
},
|
||||
"locked": {
|
||||
"lastModified": 1773132441,
|
||||
"narHash": "sha256-fv5MurEa6CZt6gwZ2Gr7CU8g4OyuMfTrmmEKO8MYPvc=",
|
||||
"lastModified": 1773927313,
|
||||
"narHash": "sha256-2XjQPMd79Z5hOS67rjCuDyiIW4I7XpBe/7yYRSyhA8k=",
|
||||
"owner": "FirelightFlagboy",
|
||||
"repo": "parsec-cloud-nix",
|
||||
"rev": "cc60bedad264efec120f87a9fb536317878ee3c7",
|
||||
"rev": "b45bbf594b3031583c5b2c9609f6c5ebdc4df903",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
@@ -186,6 +206,7 @@
|
||||
"inputs": {
|
||||
"claude-desktop": "claude-desktop",
|
||||
"flake-utils": "flake-utils",
|
||||
"home-manager": "home-manager",
|
||||
"nixpkgs": "nixpkgs",
|
||||
"parsec-cloud-nix": "parsec-cloud-nix",
|
||||
"sops-nix": "sops-nix",
|
||||
@@ -195,11 +216,11 @@
|
||||
"rust-analyzer-src": {
|
||||
"flake": false,
|
||||
"locked": {
|
||||
"lastModified": 1772938598,
|
||||
"narHash": "sha256-cxHbp8na0qO5U3SPGkSLzg3g9C81gJEG/7WbYPktD6o=",
|
||||
"lastModified": 1773543526,
|
||||
"narHash": "sha256-CKmkYqUi2pI1uDGDfpK0mkZbRLyjUKCpYDU3eMHtmks=",
|
||||
"owner": "rust-lang",
|
||||
"repo": "rust-analyzer",
|
||||
"rev": "51966da92da795f1cda89bef70d7c61266d4123a",
|
||||
"rev": "90c8906e6443e7cee18cece9c2621a8b1c10794c",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
@@ -216,11 +237,11 @@
|
||||
]
|
||||
},
|
||||
"locked": {
|
||||
"lastModified": 1773096132,
|
||||
"narHash": "sha256-M3zEnq9OElB7zqc+mjgPlByPm1O5t2fbUrH3t/Hm5Ag=",
|
||||
"lastModified": 1773889674,
|
||||
"narHash": "sha256-+ycaiVAk3MEshJTg35cBTUa0MizGiS+bgpYw/f8ohkg=",
|
||||
"owner": "Mic92",
|
||||
"repo": "sops-nix",
|
||||
"rev": "d1ff3b1034d5bab5d7d8086a7803c5a5968cd784",
|
||||
"rev": "29b6519f3e0780452bca0ac0be4584f04ac16cc5",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
@@ -301,11 +322,11 @@
|
||||
"nixpkgs": "nixpkgs_2"
|
||||
},
|
||||
"locked": {
|
||||
"lastModified": 1772604980,
|
||||
"narHash": "sha256-LepcA4EUgPHmQ05nYYmRvSkAB27oqm8CjfJuxPNp12k=",
|
||||
"lastModified": 1773655023,
|
||||
"narHash": "sha256-89jAxVhDIm6nFTBX3eM53NjLm36egOXYJGoPDogN4iE=",
|
||||
"owner": "netbrain",
|
||||
"repo": "zwift",
|
||||
"rev": "1cd77e180d6963e843d3b56793adaaecafe83214",
|
||||
"rev": "a015de248bac88a3eec734b6565a86e10214a486",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
|
||||
@@ -3,6 +3,9 @@
|
||||
sops-nix.url = "github:Mic92/sops-nix";
|
||||
sops-nix.inputs.nixpkgs.follows = "nixpkgs";
|
||||
|
||||
home-manager.url = "github:nix-community/home-manager";
|
||||
home-manager.inputs.nixpkgs.follows = "nixpkgs";
|
||||
|
||||
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
||||
flake-utils.url = "github:numtide/flake-utils";
|
||||
|
||||
@@ -20,7 +23,7 @@
|
||||
zwift.url = "github:netbrain/zwift";
|
||||
};
|
||||
|
||||
outputs = { self, nixpkgs, sops-nix, zwift, flake-utils, parsec-cloud-nix, claude-desktop, ... }:
|
||||
outputs = { self, nixpkgs, sops-nix, home-manager, zwift, flake-utils, parsec-cloud-nix, claude-desktop, ... }:
|
||||
let
|
||||
customConfig = import ./config.nix;
|
||||
in
|
||||
@@ -36,6 +39,7 @@
|
||||
nixosConfigurations.laptop = nixpkgs.lib.nixosSystem {
|
||||
modules = [
|
||||
sops-nix.nixosModules.sops
|
||||
home-manager.nixosModules.home-manager
|
||||
zwift.nixosModules.zwift
|
||||
./configuration.nix
|
||||
({ pkgs, lib, ...}:
|
||||
|
||||
30
modules/laptop/home-manager.nix
Normal file
30
modules/laptop/home-manager.nix
Normal file
@@ -0,0 +1,30 @@
|
||||
{ lib, customConfig, ... }:
|
||||
|
||||
let
|
||||
username = customConfig.username;
|
||||
dotconfigPath = ../../dotconfig;
|
||||
dotconfigEntries = lib.filterAttrs (name: _: !(lib.hasPrefix "." name)) (builtins.readDir dotconfigPath);
|
||||
|
||||
mkConfigEntry = name: type:
|
||||
lib.nameValuePair name (
|
||||
{
|
||||
source = dotconfigPath + "/${name}";
|
||||
force = true;
|
||||
}
|
||||
// lib.optionalAttrs (type == "directory") {
|
||||
recursive = true;
|
||||
}
|
||||
);
|
||||
in
|
||||
{
|
||||
home-manager.useGlobalPkgs = true;
|
||||
home-manager.useUserPackages = true;
|
||||
home-manager.backupFileExtension = "hm-backup";
|
||||
|
||||
home-manager.users.${username} = {
|
||||
home.stateVersion = "24.05";
|
||||
xdg.enable = true;
|
||||
|
||||
xdg.configFile = lib.mapAttrs' mkConfigEntry dotconfigEntries;
|
||||
};
|
||||
}
|
||||
@@ -50,8 +50,11 @@
|
||||
];
|
||||
|
||||
fonts.packages = with pkgs; [
|
||||
nerd-fonts.dejavu-sans-mono
|
||||
nerd-fonts.droid-sans-mono
|
||||
nerd-fonts.dejavu-sans-mono
|
||||
nerd-fonts.droid-sans-mono
|
||||
noto-fonts
|
||||
noto-fonts-cjk-sans
|
||||
noto-fonts-color-emoji
|
||||
];
|
||||
|
||||
programs.gnupg.agent = {
|
||||
|
||||
@@ -5,6 +5,13 @@
|
||||
|
||||
{ pkgs, ... }:
|
||||
|
||||
let
|
||||
updatescreen = pkgs.writeShellScript "updatescreens.sh" ''
|
||||
#!/bin/sh
|
||||
i3-msg restart
|
||||
feh --bg-fill --no-xinerama Downloads/fire1.png
|
||||
'';
|
||||
in
|
||||
{
|
||||
services.xserver.enable = true;
|
||||
services.xserver.windowManager.i3.enable = true;
|
||||
@@ -20,13 +27,72 @@
|
||||
xss-lock
|
||||
dex
|
||||
rofi
|
||||
# i3status
|
||||
# i3blocks
|
||||
polybar
|
||||
polybarFull
|
||||
oh-my-posh
|
||||
picom
|
||||
playerctl
|
||||
zscroll
|
||||
feh
|
||||
glances
|
||||
arandr
|
||||
nautilus
|
||||
brightnessctl
|
||||
busybox
|
||||
];
|
||||
|
||||
services.autorandr = {
|
||||
enable = true;
|
||||
|
||||
hooks.postswitch = {
|
||||
"desktop-refresh" = builtins.readFile updatescreen;
|
||||
};
|
||||
|
||||
profiles = {
|
||||
listriple = {
|
||||
fingerprint = {
|
||||
eDP-1 = "00ffffffffffff0006af9cd400000000141f0104a522167803f225915758952a1f505400000001010101010101010101010101010101863d80c870b026406c30aa0058d7100000180000000f0000000000000000000000000020000000fd00283c4b4b10010a202020202020000000fe004231363055414e30332e32200a0091";
|
||||
HDMI-1 = "00ffffffffffff0010ac16f04c574e300615010380342078ea1ec5ae4f34b1260e5054a54b008180a940d100714f0101010101010101283c80a070b023403020360006442100001a000000ff00463532354d313231304e574c0a000000fc0044454c4c2055323431300a2020000000fd00384c1e5111000a2020202020200150020329f15090050403020716011f121314201511062309070767030c001000382d83010000e3050301023a801871382d40582c450006442100001e011d8018711c1620582c250006442100009e011d007251d01e206e28550006442100001e8c0ad08a20e02d10103e960006442100001800000000000000000000000000003e";
|
||||
DP-1 = "00ffffffffffff0010ac16f04c3952331314010380342078ea1ec5ae4f34b1260e5054a54b008180a940d100714f0101010101010101283c80a070b023403020360006442100001a000000ff00463532354d3035363352394c0a000000fc0044454c4c2055323431300a2020000000fd00384c1e5111000a202020202020016b020329f15090100403020404011f1f1313131313132309070767030c001000002d83010000e3050000023a801871382d40582c450006442100001e011d007251d01e206e28550006442100001e011d007251d01e206e28550006442100001e011d007251d01e206e285500064421000018000000000000000000000000000077";
|
||||
};
|
||||
|
||||
config = {
|
||||
eDP-1 = {
|
||||
enable = true;
|
||||
primary = true;
|
||||
position = "1200x1020";
|
||||
mode = "1920x1200";
|
||||
rotate = "normal";
|
||||
};
|
||||
DP-1 = {
|
||||
enable = true;
|
||||
position = "3120x563";
|
||||
mode = "1920x1200";
|
||||
rotate = "normal";
|
||||
};
|
||||
HDMI-1 = {
|
||||
enable = true;
|
||||
position = "0x0";
|
||||
mode = "1920x1200";
|
||||
rotate = "left";
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
default = {
|
||||
fingerprint = {
|
||||
eDP-1 = "00ffffffffffff0006af9cd400000000141f0104a522167803f225915758952a1f505400000001010101010101010101010101010101863d80c870b026406c30aa0058d7100000180000000f0000000000000000000000000020000000fd00283c4b4b10010a202020202020000000fe004231363055414e30332e32200a0091";
|
||||
};
|
||||
|
||||
config = {
|
||||
eDP-1 = {
|
||||
enable = true;
|
||||
primary = true;
|
||||
position = "0x0";
|
||||
mode = "1920x1200";
|
||||
rotate = "normal";
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
||||
@@ -1,4 +1,4 @@
|
||||
wifi-networks: ENC[AES256_GCM,data:dl44GBBxdbWbk8loC5aH5RYwL3CwRMwf25VptiRQBNKjWpdY8SBI2mEm3rNPmeXXI/aElcCukr/OJx/uFTK6QfgUYJHz+Hybhu06k0+Iti3RUrWc/yk8OTiqhamMIdxNf3Jz330wTWHx87fCvVFveRti74Ccr0xcvS94Uj/JyCmZVs6Bj7koxnoI2ixsiziNBzK/iCT9t/z0LJWlpmCeaNfdqxnjTKuaCgYDOpe3Ukt/YPL6VTSv4kkMnEKNi+yvlpcjp2QfXXbYMLv6rf59nZcz8Ml7OL2y3DfbFbi2yarr2ZPbYYa5HbvyZm4C19/otspzazl2dXkApmgYg1i49UGla0Y1V0v91nIDbazg10w6T3hcluQvK5UNIPbntb4dq+boy1OzrojrnI8vzdydck7dluMPoAxxaGpCP1vj4+Mgq7v1R4jytrWpJFiRkZQW55UmK7R/BkinkyhTUoHh9a3yOC2KM3oyeR+LnHlzBhcItWqhvozMs/pGmQHU3+OkXvcDf4I2tQYJ5jXoNJsG/jseYsNDhgcatlb/MmuJf2Bjc1lPSGCd8jCyXyz9tZx468boczazsSO5OsPIVL76Z/x4zZj6JFXz9rUTtD8nE1juJO2JWFxMkihrtfvIWxE0+kMrxBUlE8Nw8jeBaa9E69a44SKT3N2q5ZlFZGbRj+2l7Eo7i3T61gmTrUCLZ/nyQOlZcr7T0LnJxvbbJo3GvkiZddA9HMWxRRqX8Ee1QKOvk1ufBhW3CqNtaVWxewE4Fkf/f2ejI2666NYo3fn+voUNPEwYPNobLgvtQZd8AckAiw==,iv:o8zTQ7Z7Ycq/0Q3shVM4hQmBgQp3UIlKkq25lF0Puu8=,tag:Vs84synGs0VBJmCGOcTqlg==,type:str]
|
||||
wifi-networks: ENC[AES256_GCM,data:jcHmQ+iXRW4+OeZlvMJsn7oz5Fn18BtflKwVO3eHFwAESGvXI1OZGdrO0KyH+JMftRQKgQsGsdsLtxCWQgvVUpisgsyw7EV2XnMVMARWFnVfRxX7MOIszhzJGOsrfLxWbaJ08kGYIkSoamKjQCfltdXnafHF74lZbWVI6iU2KyiRgUB9jUxo1spfeHBWRFH57fa9bWHELg/5Wn7B0AAvgdc/foArEGfbkCUdBWCrm2iR2guw/zeCkufcQdw4erhBIOSX2F48rHPcAwZKZrruut5VGqDBHpHf4++OTieA8lSd+s9LL6MecziieGL2LGEhQ9v0fdmwlvGFp6ADOJJwpwAiv0ApxLvm7dVEXbz3AN6mEhy4P2YjhiWsafOt2yBL2Dskm332ctXvGI8GR2o1d8kh/Dqf6KK/hFVdkV49HH2jr8tgive6pBAc9mPEvPfRopwOkk1cbeP9OL/WUBIAkWVMJcpSZla0TIWZidamnH46uBSX8PdsL3RKBnsTf/cC3QZnyLAWWS5pSZ3UVb5vfBZEyooDZNFfpRLAKoisGmZYOPQKGljrx0ijDz63kGgvE26OWEbgDiEgTXvLFVd2mf4czNDDo4QVdA26G/xb85ub5mEZNJLv/o24AMWeQcqivxMn4rdwjjBwypuqILjA/8qx+CKH1u9vCmsVCf6Rl+Sp9awzsulcxDS6Irs1Hu4loVDnzLo1JE7x8GU4CdiyQS/8huTvrpvWkB0aQJo0QoPh7mixP7R3fDIMUf+sB4mwl8bC2Km2ZCKl80b1SstsXOldnvK4KdXyo09LSUPJzeWE8r/qEegfTptuwLuuyUx+IPqB4qdd1cRCYSOkzJ6LGRFeqOzzOPjpucvVQeNzz8y5vskBWDgTj8+3XQ==,iv:gSu1E7qVgwEcc/k1WL49pMRHIiNRfKGS70srW1JWfqI=,tag:lW1TTxSiBv7EDTHDSNztig==,type:str]
|
||||
sops:
|
||||
age:
|
||||
- recipient: age1hhyew9sv8lqqfeza92jkxsdudhsgaef66cxalp06ez2cm9k6aqysc7mlf7
|
||||
@@ -10,7 +10,7 @@ sops:
|
||||
NENiek9YeUhXNFhuZkZzRnBIYXdGY2cKpfSlzP7uK6VFl71OYfoHBxAwrKfpJSNT
|
||||
QQUngSh6VBrWeJIxoMkJ7O+xSgwZnWc0fnrB+OpoRqy5YVctSmHERg==
|
||||
-----END AGE ENCRYPTED FILE-----
|
||||
lastmodified: "2026-03-06T15:09:08Z"
|
||||
mac: ENC[AES256_GCM,data:IaMzycI+z+icBoTlIdNfQ/wSm4KRVKj4KoDCvXhQivGdScnOiC4a/fKz1pzL7/PNRgjETUmZ0MJhicT0lTS7FJ+dTgjkDAvpXx+24ML8iVoufny7ho6VOMlPPAVkmtbIAgXq6BFTABTHu9/Y/qKGjHAA0MgPUhPn3Ku1pROQTVc=,iv:y6hUJibLuojG4WAGq85e39Qpj3b1kj9GVqzzIoNRq3w=,tag:jv4thwXAJUHciEi2Mn8VcQ==,type:str]
|
||||
lastmodified: "2026-03-21T09:20:19Z"
|
||||
mac: ENC[AES256_GCM,data:20EScEe1X57+zwxObnNTgnG57acwJGLVjXOlN9rbh1Wq0F5Ve6Z4zmiv9AFz3GBOfE2n1T9Q9GcVV5T8PNreaM8tFATBdCihTebxESq0DPhcinReaMMftH+p/785z5zCCYvBR2QV+vmt24pcOH+h8H6X2LnjL3yo1uYx4PafFDE=,iv:xJ29oD17LqXX8KDStKl0SsTASi/7TrDX8f7pAsapWbI=,tag:S/zXh5d4TLfIH7J33ej4cA==,type:str]
|
||||
unencrypted_suffix: _unencrypted
|
||||
version: 3.12.1
|
||||
|
||||
Reference in New Issue
Block a user