Compare commits
	
		
			157 Commits
		
	
	
		
			a351adb4ed
			...
			elpaca-mig
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 0899a9a264 | |||
| fb671d1401 | |||
| a18188d3b1 | |||
| 4515ea2e05 | |||
| 60e1947dd8 | |||
| 0305fa4683 | |||
| 84a1f22326 | |||
| 4cb057109f | |||
| 51d2863cdc | |||
| 0c1cd15391 | |||
| cef3b04ebd | |||
| b9f87ac490 | |||
| 3b55c26a2c | |||
| dcd38e777a | |||
| 2116f650f7 | |||
| 00139ef2fe | |||
| 2af8204750 | |||
| cd64244bd8 | |||
| 4cc68dedea | |||
| 77fe614b7b | |||
| 6bbe7f186a | |||
| 77fc296e9e | |||
| 807944f182 | |||
| 97c2779d1b | |||
| 9d900057f6 | |||
| 86b545761f | |||
| a8a66916f4 | |||
| 32d68061a5 | |||
| 94e7e738fb | |||
| 77cf8d46a3 | |||
| b5fb07519c | |||
| 0f7e3596de | |||
| 7aeed13a34 | |||
| 7f87156a58 | |||
| 8a7cec11cf | |||
| da865671ad | |||
| 3004f57c1a | |||
| f82c4fb659 | |||
| a4d6664b77 | |||
| dd256a24f4 | |||
| 03829b74ce | |||
| 29e68d1714 | |||
| c0c51f571d | |||
| 9c54be10e1 | |||
| eb69712a7c | |||
| b86cce1c12 | |||
| 1b44c66902 | |||
| b54cb9fceb | |||
| 5fae69b391 | |||
| b8d4cf59b8 | |||
| 9ab7b41780 | |||
| 4f37050c1c | |||
| 49d98cbca1 | |||
| 47ecc2a0c4 | |||
| 149de8faae | |||
| 487aae9a58 | |||
| fde42131d2 | |||
| ddbe91c669 | |||
| 74a6e98e90 | |||
| 1aaeeaedf0 | |||
| e66a48a311 | |||
| ce1ba6dd90 | |||
| 165646b395 | |||
| 4de88f623c | |||
| c656ebf8dc | |||
| 4c3ec2a29b | |||
| 6157a2b047 | |||
| d149bc7755 | |||
| 4f669db603 | |||
| eccceb0d31 | |||
| 277432379c | |||
| 4e3e75c3e2 | |||
| b2bf550aa0 | |||
| fdc4bda993 | |||
| 23a4d50b4a | |||
| 96012de10c | |||
| 83940416d2 | |||
| 6e0427d4e0 | |||
| 6f2f2c54a7 | |||
| 3d121c8908 | |||
| 66842d545a | |||
| dc0dea2695 | |||
| 3017ea1b63 | |||
| ef7e685007 | |||
| 4700030548 | |||
| 45fd9aadef | |||
| b034f12adc | |||
| 2458cb6081 | |||
| 2f49c3f86b | |||
| e7d536417c | |||
| 61752b600d | |||
| 00cfd236ab | |||
| 88937e9acc | |||
| 30146f4fdb | |||
| 737167fe3f | |||
| 5809b012c5 | |||
| 90952a3dc0 | |||
| d8dee1504e | |||
| b744be3b00 | |||
| 8b83c429d1 | |||
| 0c685bee88 | |||
| 830499c7d6 | |||
| 18ef010bf1 | |||
| a75824ee2a | |||
| 0f65575a35 | |||
| c9638dbbcd | |||
| aff5aff63f | |||
| 0dd9976a38 | |||
| a98b45590a | |||
| 6f1242b02c | |||
| 1eea8c61e7 | |||
| f0d35c59dd | |||
| e36ba46f34 | |||
| 08ef11f1ec | |||
| fa9466dadd | |||
| 0aa212b83d | |||
| 6b8789d566 | |||
| 1db30187cb | |||
| e425d5c1f6 | |||
| 98b49c63d4 | |||
| f933f5527d | |||
| 8c49d47324 | |||
| 42015c284a | |||
| 58b9a395d7 | |||
| b102fd2b85 | |||
| 4a7edcda75 | |||
| d3f552afda | |||
| e8095c2081 | |||
| f810880d90 | |||
| 4b71ea64fe | |||
| 5692999aa1 | |||
| 2c0fd64edd | |||
| ced8c34823 | |||
| b99998823c | |||
| df196fe337 | |||
| dc47f00c81 | |||
| eecea47276 | |||
| 3243829f1f | |||
| 7595aaf174 | |||
| 9f8cc149ef | |||
| 8f20c46aac | |||
| a5ba4c9cc3 | |||
| 9bdd9868be | |||
| bad70fb304 | |||
| 8d358a2cd8 | |||
| 295ed619ff | |||
| f9042e8e80 | |||
| 4ef82e4b02 | |||
| 8b07fdc391 | |||
| f09cef4606 | |||
| 627596a2fa | |||
| 310383bfa3 | |||
| 90c073deea | |||
| 6459fc06df | |||
| 0727fb807d | |||
| cc29e3b841 | |||
| 5666080f11 | 
							
								
								
									
										6
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							| @@ -1,12 +1,12 @@ | ||||
| [submodule "dotfiles/config/taffybar/taffybar"] | ||||
| 	path = dotfiles/config/taffybar/taffybar | ||||
| 	url = ../../taffybar/taffybar.git | ||||
| 	url = git@github.com:taffybar/taffybar.git | ||||
| [submodule "dotfiles/xmonad/xmonad"] | ||||
| 	path = dotfiles/config/xmonad/xmonad | ||||
| 	url = ../xmonad.git | ||||
| 	url = git@github.com:xmonad/xmonad.git | ||||
| [submodule "dotfiles/xmonad/xmonad-contrib"] | ||||
| 	path = dotfiles/config/xmonad/xmonad-contrib | ||||
| 	url = ../xmonad-contrib.git | ||||
| 	url = git@github.com:xmonad/xmonad-contrib.git | ||||
| [submodule "dotfiles/config/alacritty/themes"] | ||||
| 	path = dotfiles/config/alacritty/themes | ||||
| 	url = https://github.com/alacritty/alacritty-theme | ||||
|   | ||||
							
								
								
									
										15
									
								
								dotfiles/config/alacritty/alacritty.toml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								dotfiles/config/alacritty/alacritty.toml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| import = ["/home/imalison/.config/alacritty/themes/themes/dracula.toml"] | ||||
|  | ||||
| [font] | ||||
| size = 8 | ||||
|  | ||||
| [scrolling] | ||||
| history = 10000 | ||||
| multiplier = 3 | ||||
|  | ||||
| [window] | ||||
| decorations = "full" | ||||
|  | ||||
| [window.padding] | ||||
| x = 10 | ||||
| y = 10 | ||||
| @@ -1,34 +0,0 @@ | ||||
| scrolling: | ||||
|   # How many lines of scrollback to keep, | ||||
|   # '0' will disable scrolling. | ||||
|   history: 10000 | ||||
|  | ||||
|   # Number of lines the viewport will move for every line | ||||
|   # scrolled when scrollback is enabled (history > 0). | ||||
|   multiplier: 3 | ||||
|  | ||||
|   # Faux Scrolling | ||||
|   # | ||||
|   # The `faux_multiplier` setting controls the number | ||||
|   # of lines the terminal should scroll when the alternate | ||||
|   # screen buffer is active. This is used to allow mouse | ||||
|   # scrolling for applications like `man`. | ||||
|   # | ||||
|   # To disable this completely, set `faux_multiplier` to 0. | ||||
|   faux_multiplier: 3 | ||||
|  | ||||
|   # Automatically scroll to the bottom when new text is written | ||||
|   # to the terminal. | ||||
|   auto_scroll: false | ||||
|  | ||||
| font: | ||||
|   size: 8 | ||||
|  | ||||
| window: | ||||
|   padding: | ||||
|     x: 10 | ||||
|     y: 10 | ||||
|   decorations: full | ||||
|  | ||||
| import: | ||||
| - ~/.config/alacritty/themes/themes/dracula.yaml | ||||
							
								
								
									
										20
									
								
								dotfiles/config/autorandr/strixy-minaj-240hz-solo/config
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								dotfiles/config/autorandr/strixy-minaj-240hz-solo/config
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| output DP-0 | ||||
| off | ||||
| output DP-1 | ||||
| off | ||||
| output HDMI-0 | ||||
| off | ||||
| output DP-3 | ||||
| off | ||||
| output DP-4 | ||||
| off | ||||
| output DP-5 | ||||
| off | ||||
| output DP-6 | ||||
| off | ||||
| output DP-2 | ||||
| crtc 0 | ||||
| mode 2560x1600 | ||||
| pos 0x0 | ||||
| rate 240.00 | ||||
| x-prop-non_desktop 0 | ||||
							
								
								
									
										1
									
								
								dotfiles/config/autorandr/strixy-minaj-240hz-solo/setup
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								dotfiles/config/autorandr/strixy-minaj-240hz-solo/setup
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| DP-2 00ffffffffffff0009e5580c0000000001210104b527187803bbc5ae503fb7250c515500000001010101010101010101010101010101c07200a0a040c8603020360084f21000001a000000fd0c30f0b1b176010a202020202020000000fe00424f452043510a202020202020000000fc004e4531383051444d2d4e4d310a029602030f00e3058080e606050195731000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000fa702079020021001d280f7409000a400680dd2a511824b249120e023554b060ec64662a1378220014ffed1185ff099f002f001f003f06c700020005002b000c27003cef00002700303b0000810015741a0000030b30f0006095107310f0000000008d00000000000000000000000000000000000000000000000000000000bc90 | ||||
| @@ -1,63 +0,0 @@ | ||||
| # Beware! This file is rewritten by htop when settings are changed in the interface. | ||||
| # The parser is also very primitive, and not human-friendly. | ||||
| htop_version=3.2.2 | ||||
| config_reader_min_version=3 | ||||
| fields=0 48 17 18 38 39 40 2 46 47 49 1 | ||||
| hide_kernel_threads=1 | ||||
| hide_userland_threads=1 | ||||
| hide_running_in_container=0 | ||||
| shadow_other_users=0 | ||||
| show_thread_names=0 | ||||
| show_program_path=1 | ||||
| highlight_base_name=0 | ||||
| highlight_deleted_exe=1 | ||||
| shadow_distribution_path_prefix=0 | ||||
| highlight_megabytes=1 | ||||
| highlight_threads=0 | ||||
| highlight_changes=0 | ||||
| highlight_changes_delay_secs=5 | ||||
| find_comm_in_cmdline=1 | ||||
| strip_exe_from_cmdline=1 | ||||
| show_merged_command=0 | ||||
| header_margin=1 | ||||
| screen_tabs=0 | ||||
| detailed_cpu_time=0 | ||||
| cpu_count_from_one=1 | ||||
| show_cpu_usage=1 | ||||
| show_cpu_frequency=0 | ||||
| show_cpu_temperature=0 | ||||
| degree_fahrenheit=0 | ||||
| update_process_names=0 | ||||
| account_guest_in_cpu_meter=0 | ||||
| color_scheme=0 | ||||
| enable_mouse=1 | ||||
| delay=15 | ||||
| hide_function_bar=0 | ||||
| header_layout=two_50_50 | ||||
| column_meters_0=AllCPUs Memory Swap | ||||
| column_meter_modes_0=1 1 1 | ||||
| column_meters_1=Tasks LoadAverage Uptime | ||||
| column_meter_modes_1=2 2 2 | ||||
| tree_view=0 | ||||
| sort_key=46 | ||||
| tree_sort_key=46 | ||||
| sort_direction=-1 | ||||
| tree_sort_direction=-1 | ||||
| tree_view_always_by_pid=0 | ||||
| all_branches_collapsed=0 | ||||
| screen:Main=PID USER PRIORITY NICE M_VIRT M_RESIDENT M_SHARE STATE PERCENT_CPU PERCENT_MEM TIME Command | ||||
| .sort_key=PERCENT_CPU | ||||
| .tree_sort_key=PERCENT_CPU | ||||
| .tree_view=0 | ||||
| .tree_view_always_by_pid=0 | ||||
| .sort_direction=-1 | ||||
| .tree_sort_direction=-1 | ||||
| .all_branches_collapsed=0 | ||||
| screen:I/O=PID USER IO_PRIORITY IO_RATE IO_READ_RATE IO_WRITE_RATE PERCENT_SWAP_DELAY PERCENT_IO_DELAY Command | ||||
| .sort_key=IO_RATE | ||||
| .tree_sort_key=PID | ||||
| .tree_view=0 | ||||
| .tree_view_always_by_pid=0 | ||||
| .sort_direction=-1 | ||||
| .tree_sort_direction=1 | ||||
| .all_branches_collapsed=0 | ||||
							
								
								
									
										699
									
								
								dotfiles/config/taffybar/flake.lock
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										699
									
								
								dotfiles/config/taffybar/flake.lock
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,699 @@ | ||||
| { | ||||
|   "nodes": { | ||||
|     "flake-compat": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "lastModified": 1673956053, | ||||
|         "narHash": "sha256-4gtG9iQuiKITOjNQQeQIpoIB6b16fm+504Ch3sNKLd8=", | ||||
|         "owner": "edolstra", | ||||
|         "repo": "flake-compat", | ||||
|         "rev": "35bb57c0c8d8b62bbfd284272c928ceb64ddbde9", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "edolstra", | ||||
|         "repo": "flake-compat", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "flake-utils": { | ||||
|       "inputs": { | ||||
|         "systems": "systems" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1701680307, | ||||
|         "narHash": "sha256-kAuep2h5ajznlPMD9rnQyffWG8EM/C73lejGofXvdM8=", | ||||
|         "owner": "numtide", | ||||
|         "repo": "flake-utils", | ||||
|         "rev": "4022d587cbbfd70fe950c1e2083a02621806a725", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "numtide", | ||||
|         "repo": "flake-utils", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "flake-utils_2": { | ||||
|       "inputs": { | ||||
|         "systems": "systems_2" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1689068808, | ||||
|         "narHash": "sha256-6ixXo3wt24N/melDWjq70UuHQLxGV8jZvooRanIHXw0=", | ||||
|         "owner": "numtide", | ||||
|         "repo": "flake-utils", | ||||
|         "rev": "919d646de7be200f3bf08cb76ae1f09402b6f9b4", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "numtide", | ||||
|         "repo": "flake-utils", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "flake-utils_3": { | ||||
|       "inputs": { | ||||
|         "systems": "systems_3" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1685518550, | ||||
|         "narHash": "sha256-o2d0KcvaXzTrPRIo0kOLV0/QXHhDQ5DTi+OxcjO8xqY=", | ||||
|         "owner": "numtide", | ||||
|         "repo": "flake-utils", | ||||
|         "rev": "a1720a10a6cfe8234c0e93907ffe81be440f4cef", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "numtide", | ||||
|         "repo": "flake-utils", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "flake-utils_4": { | ||||
|       "inputs": { | ||||
|         "systems": "systems_4" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1701680307, | ||||
|         "narHash": "sha256-kAuep2h5ajznlPMD9rnQyffWG8EM/C73lejGofXvdM8=", | ||||
|         "owner": "numtide", | ||||
|         "repo": "flake-utils", | ||||
|         "rev": "4022d587cbbfd70fe950c1e2083a02621806a725", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "numtide", | ||||
|         "repo": "flake-utils", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "fourmolu-011": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "narHash": "sha256-g/yDZXeLCHq/iXoZTaTYSb8l9CMny3AKsRQgWElagZI=", | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/fourmolu-0.11.0.0/fourmolu-0.11.0.0.tar.gz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/fourmolu-0.11.0.0/fourmolu-0.11.0.0.tar.gz" | ||||
|       } | ||||
|     }, | ||||
|     "fourmolu-012": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "narHash": "sha256-yru8ls67DMM6WSeVU6xDmmwa48I8S9CUv9NBaxSQ29M=", | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/fourmolu-0.12.0.0/fourmolu-0.12.0.0.tar.gz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/fourmolu-0.12.0.0/fourmolu-0.12.0.0.tar.gz" | ||||
|       } | ||||
|     }, | ||||
|     "git-ignore-nix": { | ||||
|       "inputs": { | ||||
|         "nixpkgs": [ | ||||
|           "taffybar", | ||||
|           "nixpkgs" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1660459072, | ||||
|         "narHash": "sha256-8DFJjXG8zqoONA1vXtgeKXy68KdJL5UaXR8NtVMUbx8=", | ||||
|         "owner": "hercules-ci", | ||||
|         "repo": "gitignore.nix", | ||||
|         "rev": "a20de23b925fd8264fd7fad6454652e142fd7f73", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "hercules-ci", | ||||
|         "ref": "master", | ||||
|         "repo": "gitignore.nix", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "git-ignore-nix_2": { | ||||
|       "inputs": { | ||||
|         "nixpkgs": "nixpkgs_4" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1703887061, | ||||
|         "narHash": "sha256-gGPa9qWNc6eCXT/+Z5/zMkyYOuRZqeFZBDbopNZQkuY=", | ||||
|         "owner": "hercules-ci", | ||||
|         "repo": "gitignore.nix", | ||||
|         "rev": "43e1aa1308018f37118e34d3a9cb4f5e75dc11d5", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "hercules-ci", | ||||
|         "ref": "master", | ||||
|         "repo": "gitignore.nix", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "gitignore": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "lastModified": 1660459072, | ||||
|         "narHash": "sha256-8DFJjXG8zqoONA1vXtgeKXy68KdJL5UaXR8NtVMUbx8=", | ||||
|         "owner": "hercules-ci", | ||||
|         "repo": "gitignore.nix", | ||||
|         "rev": "a20de23b925fd8264fd7fad6454652e142fd7f73", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "hercules-ci", | ||||
|         "repo": "gitignore.nix", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "gtk-sni-tray": { | ||||
|       "inputs": { | ||||
|         "flake-utils": [ | ||||
|           "taffybar", | ||||
|           "flake-utils" | ||||
|         ], | ||||
|         "git-ignore-nix": [ | ||||
|           "taffybar", | ||||
|           "git-ignore-nix" | ||||
|         ], | ||||
|         "nixpkgs": [ | ||||
|           "taffybar", | ||||
|           "nixpkgs" | ||||
|         ], | ||||
|         "status-notifier-item": [ | ||||
|           "taffybar", | ||||
|           "status-notifier-item" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1663379298, | ||||
|         "narHash": "sha256-m18+G7V1N+g/pPeKJG9hkblGA5c8QTnUYnsU5t14sOw=", | ||||
|         "owner": "taffybar", | ||||
|         "repo": "gtk-sni-tray", | ||||
|         "rev": "1927d86308d34b5d21a709cf8ff5332ec5d37de4", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "taffybar", | ||||
|         "ref": "master", | ||||
|         "repo": "gtk-sni-tray", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "gtk-strut": { | ||||
|       "inputs": { | ||||
|         "flake-utils": [ | ||||
|           "taffybar", | ||||
|           "flake-utils" | ||||
|         ], | ||||
|         "git-ignore-nix": [ | ||||
|           "taffybar", | ||||
|           "git-ignore-nix" | ||||
|         ], | ||||
|         "nixpkgs": [ | ||||
|           "taffybar", | ||||
|           "nixpkgs" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1663377859, | ||||
|         "narHash": "sha256-UrBd+R3NaJIDC2lt5gMafS3KBeLs83emm2YorX2cFCo=", | ||||
|         "owner": "taffybar", | ||||
|         "repo": "gtk-strut", | ||||
|         "rev": "d946eb230cdccf5afc063642b3215723e555990b", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "taffybar", | ||||
|         "ref": "master", | ||||
|         "repo": "gtk-strut", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "haskell-hie-bios": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "lastModified": 1686930638, | ||||
|         "narHash": "sha256-gfcxxHtZ2jUsiKNn/O4jEkfWF/2H04aTnaIvPDbtNlQ=", | ||||
|         "owner": "haskell", | ||||
|         "repo": "hie-bios", | ||||
|         "rev": "3d4fadfb0dc44cb287db9897ecfb503899d33513", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "haskell", | ||||
|         "repo": "hie-bios", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "haskell-implicit-hie-cradle": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "lastModified": 1686495518, | ||||
|         "narHash": "sha256-OAe+zOkMZuoTfVEMnxnCT1cmPgRF/riAR8nVdomnwxo=", | ||||
|         "owner": "smunix", | ||||
|         "repo": "implicit-hie-cradle", | ||||
|         "rev": "d6aa00355898469af56cfd5e62f7fc8bd9959ded", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "smunix", | ||||
|         "ref": "smunix-patch-hls-0.5-1", | ||||
|         "repo": "implicit-hie-cradle", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "haskell-language-server": { | ||||
|       "inputs": { | ||||
|         "flake-compat": "flake-compat", | ||||
|         "flake-utils": "flake-utils_3", | ||||
|         "fourmolu-011": "fourmolu-011", | ||||
|         "fourmolu-012": "fourmolu-012", | ||||
|         "gitignore": "gitignore", | ||||
|         "haskell-hie-bios": "haskell-hie-bios", | ||||
|         "haskell-implicit-hie-cradle": "haskell-implicit-hie-cradle", | ||||
|         "hiedb": "hiedb", | ||||
|         "hlint-35": "hlint-35", | ||||
|         "hlint-36": "hlint-36", | ||||
|         "lsp": "lsp", | ||||
|         "lsp-test": "lsp-test", | ||||
|         "lsp-types": "lsp-types", | ||||
|         "nixpkgs": "nixpkgs_2", | ||||
|         "ormolu-052": "ormolu-052", | ||||
|         "ormolu-07": "ormolu-07", | ||||
|         "stylish-haskell-0145": "stylish-haskell-0145" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1693851896, | ||||
|         "narHash": "sha256-799JUHpBd2iMRCrTYDme5RsROKnIwSKBe2xYxgVN7QI=", | ||||
|         "owner": "colonelpanic8", | ||||
|         "repo": "haskell-language-server", | ||||
|         "rev": "ea368cef0673059fff95e953ef983109b5979dbc", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "colonelpanic8", | ||||
|         "ref": "goto-dependency-definition-2", | ||||
|         "repo": "haskell-language-server", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "hiedb": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "lastModified": 1691542357, | ||||
|         "narHash": "sha256-90ftphhoIo0CklJrjfCGQrZIUKZfdMJ2Og6tep9dmJ8=", | ||||
|         "owner": "nlander", | ||||
|         "repo": "HieDb", | ||||
|         "rev": "4eebfcf8fab54f24808e6301227d77ae64d2509c", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nlander", | ||||
|         "ref": "all-new-functions", | ||||
|         "repo": "HieDb", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "hlint-35": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "narHash": "sha256-qQNUlQQnahUGEO92Lm0RwjTGBGr2Yaw0KRuFRMoc5No=", | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/hlint-3.5/hlint-3.5.tar.gz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/hlint-3.5/hlint-3.5.tar.gz" | ||||
|       } | ||||
|     }, | ||||
|     "hlint-36": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "narHash": "sha256-fH4RYnWeuBqJI5d3Ba+Xs0BxYr0IYFH1OWO3k2iHGlU=", | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/hlint-3.6.1/hlint-3.6.1.tar.gz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/hlint-3.6.1/hlint-3.6.1.tar.gz" | ||||
|       } | ||||
|     }, | ||||
|     "lsp": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "narHash": "sha256-HcEfdYUrCHufEa+10M2wESjnK41xM/msd+t6r6JwQO0=", | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/lsp-2.2.0.0/lsp-2.2.0.0.tar.gz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/lsp-2.2.0.0/lsp-2.2.0.0.tar.gz" | ||||
|       } | ||||
|     }, | ||||
|     "lsp-test": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "narHash": "sha256-E1D3X2+I9ZTZLpHDEDTXexQFYpyG5byOFRIvRTeBsn8=", | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/lsp-test-0.16.0.0/lsp-test-0.16.0.0.tar.gz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/lsp-test-0.16.0.0/lsp-test-0.16.0.0.tar.gz" | ||||
|       } | ||||
|     }, | ||||
|     "lsp-types": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "narHash": "sha256-Oa5HuKdsdTSQUKtuSt06zVAq19Qxq5IJZObrnPwlB6s=", | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/lsp-types-2.0.2.0/lsp-types-2.0.2.0.tar.gz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/lsp-types-2.0.2.0/lsp-types-2.0.2.0.tar.gz" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs": { | ||||
|       "locked": { | ||||
|         "lastModified": 1702312524, | ||||
|         "narHash": "sha256-gkZJRDBUCpTPBvQk25G0B7vfbpEYM5s5OZqghkjZsnE=", | ||||
|         "path": "/nix/store/4fgs7yzsy2dqnjw8j42qlp9i1vgarzy0-source", | ||||
|         "rev": "a9bf124c46ef298113270b1f84a164865987a91c", | ||||
|         "type": "path" | ||||
|       }, | ||||
|       "original": { | ||||
|         "id": "nixpkgs", | ||||
|         "type": "indirect" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs_2": { | ||||
|       "locked": { | ||||
|         "lastModified": 1686874404, | ||||
|         "narHash": "sha256-u2Ss8z+sGaVlKtq7sCovQ8WvXY+OoXJmY1zmyxITiaY=", | ||||
|         "owner": "NixOS", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "efc10371d5c5b8d2d58bab6c1100753efacfe550", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "NixOS", | ||||
|         "ref": "haskell-updates", | ||||
|         "repo": "nixpkgs", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs_3": { | ||||
|       "locked": { | ||||
|         "lastModified": 1689098530, | ||||
|         "narHash": "sha256-fxc/9f20wRyo/5ydkmZkX/Sh/ULa7RcT8h+cUv8p/44=", | ||||
|         "owner": "NixOS", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "f2406198ea0e4e37d4380d0e20336c575b8f8ef9", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "NixOS", | ||||
|         "ref": "nixos-unstable", | ||||
|         "repo": "nixpkgs", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs_4": { | ||||
|       "locked": { | ||||
|         "lastModified": 1666603677, | ||||
|         "narHash": "sha256-apAEIj+z1iwMaMJ4tB21r/VTetfGDLDzuhXRHJknIAU=", | ||||
|         "owner": "NixOS", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "074da18a72269cc5a6cf444dce42daea5649b2fe", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "id": "nixpkgs", | ||||
|         "type": "indirect" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs_5": { | ||||
|       "locked": { | ||||
|         "lastModified": 1702312524, | ||||
|         "narHash": "sha256-gkZJRDBUCpTPBvQk25G0B7vfbpEYM5s5OZqghkjZsnE=", | ||||
|         "path": "/nix/store/4fgs7yzsy2dqnjw8j42qlp9i1vgarzy0-source", | ||||
|         "rev": "a9bf124c46ef298113270b1f84a164865987a91c", | ||||
|         "type": "path" | ||||
|       }, | ||||
|       "original": { | ||||
|         "id": "nixpkgs", | ||||
|         "type": "indirect" | ||||
|       } | ||||
|     }, | ||||
|     "ormolu-052": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "narHash": "sha256-H7eqId488RBRxcf7flgJefAZmRgFJASJva+Oy7GG4q4=", | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/ormolu-0.5.2.0/ormolu-0.5.2.0.tar.gz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/ormolu-0.5.2.0/ormolu-0.5.2.0.tar.gz" | ||||
|       } | ||||
|     }, | ||||
|     "ormolu-07": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "narHash": "sha256-5M5gNzSvsiQH1+0oexRByzf5EIET+0BFwR4fLIr2P7g=", | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/ormolu-0.7.1.0/ormolu-0.7.1.0.tar.gz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/ormolu-0.7.1.0/ormolu-0.7.1.0.tar.gz" | ||||
|       } | ||||
|     }, | ||||
|     "root": { | ||||
|       "inputs": { | ||||
|         "flake-utils": "flake-utils", | ||||
|         "nixpkgs": "nixpkgs", | ||||
|         "taffybar": "taffybar", | ||||
|         "xmonad": "xmonad_2" | ||||
|       } | ||||
|     }, | ||||
|     "status-notifier-item": { | ||||
|       "inputs": { | ||||
|         "flake-utils": [ | ||||
|           "taffybar", | ||||
|           "flake-utils" | ||||
|         ], | ||||
|         "git-ignore-nix": [ | ||||
|           "taffybar", | ||||
|           "git-ignore-nix" | ||||
|         ], | ||||
|         "nixpkgs": [ | ||||
|           "taffybar", | ||||
|           "nixpkgs" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1641783528, | ||||
|         "narHash": "sha256-wJymJfYPFj4/r1e4kT/wt9FEsyCXo5JkkcOoozpuhag=", | ||||
|         "owner": "taffybar", | ||||
|         "repo": "status-notifier-item", | ||||
|         "rev": "f4f9c66ab57fc42eeed0de8cfac9f5f9d30d9dc7", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "taffybar", | ||||
|         "repo": "status-notifier-item", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "stylish-haskell-0145": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "narHash": "sha256-EE7RFQ6q4Ek8daRgOpNMGepYLa9o8cM4OLjTNUSHQf0=", | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/stylish-haskell-0.14.5.0/stylish-haskell-0.14.5.0.tar.gz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://hackage.haskell.org/package/stylish-haskell-0.14.5.0/stylish-haskell-0.14.5.0.tar.gz" | ||||
|       } | ||||
|     }, | ||||
|     "systems": { | ||||
|       "locked": { | ||||
|         "lastModified": 1681028828, | ||||
|         "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", | ||||
|         "owner": "nix-systems", | ||||
|         "repo": "default", | ||||
|         "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nix-systems", | ||||
|         "repo": "default", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "systems_2": { | ||||
|       "locked": { | ||||
|         "lastModified": 1681028828, | ||||
|         "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", | ||||
|         "owner": "nix-systems", | ||||
|         "repo": "default", | ||||
|         "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nix-systems", | ||||
|         "repo": "default", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "systems_3": { | ||||
|       "locked": { | ||||
|         "lastModified": 1681028828, | ||||
|         "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", | ||||
|         "owner": "nix-systems", | ||||
|         "repo": "default", | ||||
|         "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nix-systems", | ||||
|         "repo": "default", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "systems_4": { | ||||
|       "locked": { | ||||
|         "lastModified": 1681028828, | ||||
|         "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", | ||||
|         "owner": "nix-systems", | ||||
|         "repo": "default", | ||||
|         "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nix-systems", | ||||
|         "repo": "default", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "taffybar": { | ||||
|       "inputs": { | ||||
|         "flake-utils": "flake-utils_2", | ||||
|         "git-ignore-nix": "git-ignore-nix", | ||||
|         "gtk-sni-tray": "gtk-sni-tray", | ||||
|         "gtk-strut": "gtk-strut", | ||||
|         "haskell-language-server": "haskell-language-server", | ||||
|         "nixpkgs": "nixpkgs_3", | ||||
|         "status-notifier-item": "status-notifier-item", | ||||
|         "xmonad": "xmonad" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1696612500, | ||||
|         "narHash": "sha256-Q19F91yVQviqxgY+FkvEwtX2vcw414eVtK8erim0NrU=", | ||||
|         "owner": "taffybar", | ||||
|         "repo": "taffybar", | ||||
|         "rev": "46eba89c2a4d4ffefe42c3ee4506d1b74c8e61fd", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "taffybar", | ||||
|         "repo": "taffybar", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "unstable": { | ||||
|       "locked": { | ||||
|         "lastModified": 1689098530, | ||||
|         "narHash": "sha256-fxc/9f20wRyo/5ydkmZkX/Sh/ULa7RcT8h+cUv8p/44=", | ||||
|         "owner": "NixOS", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "f2406198ea0e4e37d4380d0e20336c575b8f8ef9", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "NixOS", | ||||
|         "ref": "nixos-unstable", | ||||
|         "repo": "nixpkgs", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "unstable_2": { | ||||
|       "locked": { | ||||
|         "lastModified": 1704538339, | ||||
|         "narHash": "sha256-1734d3mQuux9ySvwf6axRWZRBhtcZA9Q8eftD6EZg6U=", | ||||
|         "owner": "NixOS", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "46ae0210ce163b3cba6c7da08840c1d63de9c701", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "NixOS", | ||||
|         "ref": "nixos-unstable", | ||||
|         "repo": "nixpkgs", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "xmonad": { | ||||
|       "inputs": { | ||||
|         "flake-utils": [ | ||||
|           "taffybar", | ||||
|           "flake-utils" | ||||
|         ], | ||||
|         "git-ignore-nix": [ | ||||
|           "taffybar", | ||||
|           "git-ignore-nix" | ||||
|         ], | ||||
|         "nixpkgs": [ | ||||
|           "taffybar", | ||||
|           "nixpkgs" | ||||
|         ], | ||||
|         "unstable": "unstable" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1687976934, | ||||
|         "narHash": "sha256-hUZmKy3jJ1+5rTGeQzfNR+LxgzmLaaeRVnbsJMEVw0Q=", | ||||
|         "owner": "xmonad", | ||||
|         "repo": "xmonad", | ||||
|         "rev": "1aac6611d82065c9198e5584176058a9483fcbb0", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "xmonad", | ||||
|         "ref": "master", | ||||
|         "repo": "xmonad", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "xmonad_2": { | ||||
|       "inputs": { | ||||
|         "flake-utils": "flake-utils_4", | ||||
|         "git-ignore-nix": "git-ignore-nix_2", | ||||
|         "nixpkgs": "nixpkgs_5", | ||||
|         "unstable": "unstable_2" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1702895348, | ||||
|         "narHash": "sha256-ADRTw4DTfDCmsSFFWZKmvdmIjnEVY7pjjUxYytKXy1E=", | ||||
|         "owner": "xmonad", | ||||
|         "repo": "xmonad", | ||||
|         "rev": "c4cf4715f736fed77fb2af622c0760259ac2cf43", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "xmonad", | ||||
|         "ref": "master", | ||||
|         "repo": "xmonad", | ||||
|         "type": "github" | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   "root": "root", | ||||
|   "version": 7 | ||||
| } | ||||
| @@ -2,11 +2,14 @@ | ||||
|   inputs = { | ||||
|     flake-utils.url = github:numtide/flake-utils; | ||||
|     xmonad.url = github:xmonad/xmonad/master; | ||||
|     taffybar.url = path:./taffybar; | ||||
|     taffybar.url = "github:taffybar/taffybar"; | ||||
|   }; | ||||
|   outputs = { self, flake-utils, taffybar, nixpkgs, xmonad }: | ||||
|   let | ||||
|     hoverlay = final: prev: hself: hsuper: { | ||||
|       taffybar = hsuper.taffybar.overrideAttrs (old: { | ||||
|         doHaddock = false; | ||||
|       }); | ||||
|       imalison-taffybar = prev.haskell.lib.addPkgconfigDepends ( | ||||
|         hself.callCabal2nix "imalison-taffybar" | ||||
|         ( | ||||
|   | ||||
 Submodule dotfiles/config/taffybar/taffybar updated: 067e0bff51...9c8540a564
									
								
							| @@ -226,12 +226,14 @@ main = do | ||||
|                          , startWidgets = [myWorkspaces, myLayout] | ||||
|                          } | ||||
|             ) | ||||
|           , ( "strixi-minaj" | ||||
|             , baseConfig { endWidgets = laptopEndWidgets } | ||||
|             ) | ||||
|           , ( "jay-lenovo" | ||||
|             , baseConfig { endWidgets = laptopEndWidgets } | ||||
|             ), | ||||
|             ( "nixquick" | ||||
|           , baseConfig { endWidgets = [ myTray , myMpris ] | ||||
|                        } | ||||
|             ) | ||||
|           , ( "nixquick" | ||||
|             , baseConfig { endWidgets = [ myTray , myMpris ] } | ||||
|             ) | ||||
|  | ||||
|           ] | ||||
|   | ||||
 Submodule dotfiles/config/xmonad/xmonad-contrib updated: b5ef6265b8...229c7baf00
									
								
							| @@ -54,12 +54,14 @@ | ||||
|         sp-remove-active-pair-overlay | ||||
|         sp-splice-sexp | ||||
|         sp-splice-sexp-killing-backward | ||||
|         string-inflection-all-cycle | ||||
|         string-inflection-toggle | ||||
|         tern-ac-dot-complete | ||||
|         transpose-sexps | ||||
|         transpose-words | ||||
|         undo-redo | ||||
|         universal-argument-minus | ||||
|         upcase-region | ||||
|         wdired-finish-edit | ||||
|         yaml-electric-backspace | ||||
|         yaml-electric-dash-and-dot | ||||
| @@ -83,6 +85,7 @@ | ||||
|         imalison:multiple-cursors-hydra/mc/mark-previous-like-this | ||||
|         imalison:multiple-cursors-hydra/nil | ||||
|         isearch-delete-char | ||||
|         lsp-ui-doc--handle-mouse-movement | ||||
|         make-frame | ||||
|         overwrite-mode | ||||
|         smex | ||||
|   | ||||
| @@ -361,6 +361,8 @@ but provide support for writing custom elisp. | ||||
| *** shut-up | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package shut-up | ||||
|   :demand t | ||||
|   :ensure (:inherit t :wait t) | ||||
|   :config | ||||
|   (defun imalison:shut-up-around (function &rest args) | ||||
|     (shut-up (apply function args)))) | ||||
| @@ -856,6 +858,7 @@ details. | ||||
|               (directory-files filepath)))) | ||||
|  | ||||
| (use-package eshell | ||||
|   :ensure nil | ||||
|   :commands (eshell-parse-colon-path imalison:get-executables-on-path) | ||||
|   :config | ||||
|   (defun imalison:get-executables-on-path () | ||||
| @@ -1233,6 +1236,7 @@ This makes ~forward-word~ and ~backward-word~ understand snake and camel case. | ||||
| proced is an top like utility that runs inside of emacs. The following sets auto updating automatically and makes the update interval faster. | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package proced | ||||
|   :ensure nil | ||||
|   :defer t | ||||
|   :config | ||||
|   (progn | ||||
| @@ -1376,6 +1380,7 @@ Paradox is a package.el extension. I have no use for it now that I use straight. | ||||
| ** server | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package server | ||||
|   :ensure nil | ||||
|   :demand t | ||||
|   :config | ||||
|   (progn | ||||
| @@ -1444,19 +1449,6 @@ The file server file for this emacs instance no longer exists.") | ||||
| (use-package refine | ||||
|   :disabled t) | ||||
| #+END_SRC | ||||
| ** winner | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package winner | ||||
|   :commands (winner-undo winner-redo) | ||||
|   :bind ("C-c q" . imalison:winner-hydra/body) | ||||
|   :config | ||||
|   (progn | ||||
|     (defhydra imalison:winner-hydra () | ||||
|       "Winner" | ||||
|       ("p" winner-undo "back") | ||||
|       ("n" winner-redo "forward" :exit t)) | ||||
|     (winner-mode 1))) | ||||
| #+END_SRC | ||||
| ** eyebrowse | ||||
| I don't have any use for this now that I use frames mode, but its an interesting idea. | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| @@ -1521,11 +1513,10 @@ custom-set-faces in your custom file. | ||||
| (use-package highlight-indent-guides | ||||
|   :commands highlight-indent-guides-mode | ||||
|   :diminish highlight-indent-guides-mode | ||||
|   :preface | ||||
|   (progn | ||||
|     (add-hook 'prog-mode-hook 'highlight-indent-guides-mode)) | ||||
|   :demand t | ||||
|   :config | ||||
|   (progn | ||||
|     (add-hook 'prog-mode-hook 'highlight-indent-guides-mode) | ||||
|     (setq highlight-indent-guides-method 'fill))) | ||||
| #+END_SRC | ||||
| ** man-mode | ||||
| @@ -1534,6 +1525,7 @@ fixes that, but for now, it needs to be run manually, since I haven't figured | ||||
| out how to detect that a buffer is a man mode buffer. | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package man | ||||
|   :ensure nil | ||||
|   :config | ||||
|   (progn | ||||
|     (defun imalison:fontify-man-page-buffer () | ||||
| @@ -1759,6 +1751,7 @@ bind-key and global-set-key forms. | ||||
| #+END_SRC | ||||
| ** projectile | ||||
| #+BEGIN_SRC emacs-lisp | ||||
|  | ||||
| (use-package projectile | ||||
|   :demand t | ||||
|   :bind (:map projectile-mode-map | ||||
| @@ -1772,7 +1765,7 @@ bind-key and global-set-key forms. | ||||
|    (projectile-git-submodule-command nil) | ||||
|    (project-vc-merge-submodules nil) | ||||
|    (projectile-current-project-on-switch 'keep)) | ||||
|   :preface | ||||
|   :config | ||||
|   (progn | ||||
|     (defmacro imalison:projectile-do-in-project (project-dir &rest forms) | ||||
|       `(imalison:with-default-directory ,project-dir | ||||
| @@ -1804,9 +1797,7 @@ bind-key and global-set-key forms. | ||||
|                     (write-region "" nil | ||||
|                                   (expand-file-name | ||||
|                                    (concat directory "/" | ||||
|                                            (nth 0 file-info) "/.projectile"))))))) | ||||
|   :config | ||||
|   (progn | ||||
|                                            (nth 0 file-info) "/.projectile")))))) | ||||
|     (projectile-global-mode) | ||||
|     (diminish 'projectile-mode))) | ||||
| #+END_SRC | ||||
| @@ -1855,7 +1846,8 @@ bind-key and global-set-key forms. | ||||
| ** avy | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package avy | ||||
|   :preface | ||||
|   :after emit | ||||
|   :config | ||||
|   (progn | ||||
|     (emit-prefix-selector imalison:avy | ||||
|       avy-goto-word-1 | ||||
| @@ -1867,11 +1859,13 @@ bind-key and global-set-key forms. | ||||
| ** ace-window | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package ace-window | ||||
|   :preface | ||||
|   :after emit | ||||
|   :config | ||||
|   (progn | ||||
|     (emit-prefix-selector imalison:ace-window | ||||
|       ace-select-window | ||||
|       ace-swap-window) | ||||
|   :config (setq aw-keys '(?a ?s ?d ?f ?g ?h ?j ?k ?l)) | ||||
|     (setq aw-keys '(?a ?s ?d ?f ?g ?h ?j ?k ?l))) | ||||
|   :bind ("C-c w" . imalison:ace-window)) | ||||
| #+END_SRC | ||||
| ** neotree | ||||
| @@ -1897,7 +1891,7 @@ Neotree is useless with frame mode for now, so I've disabled it. | ||||
| * Completion | ||||
| ** vertico | ||||
| #+begin_src emacs-lisp | ||||
| (use-package vertico | ||||
|   (use-package vertico | ||||
| 	:demand t | ||||
| 	:config | ||||
| 	(progn | ||||
| @@ -2026,10 +2020,12 @@ Neotree is useless with frame mode for now, so I've disabled it. | ||||
| ** company | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package company | ||||
|   :after emit | ||||
|   :commands company-mode imalison:company | ||||
|   :bind (("C-\\" . imalison:company)) | ||||
|   :config | ||||
|   (progn | ||||
|     (add-hook 'prog-mode-hook (lambda () (company-mode t))) | ||||
|     (emit-prefix-selector imalison:company | ||||
|       company-complete | ||||
|       company-yasnippet) | ||||
| @@ -2039,9 +2035,7 @@ Neotree is useless with frame mode for now, so I've disabled it. | ||||
|       :demand t | ||||
|       :config (company-prescient-mode +1)) | ||||
|     (global-company-mode) | ||||
|     (diminish 'company-mode)) | ||||
|   :init | ||||
|   (add-hook 'prog-mode-hook (lambda () (company-mode t)))) | ||||
|     (diminish 'company-mode))) | ||||
| #+END_SRC | ||||
| *** company-flx | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| @@ -2214,6 +2208,7 @@ I don't use auto-complete at all, so I have set up a hook to automatically disab | ||||
| ** align | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package align | ||||
|   :ensure nil | ||||
|   :bind ("C-c C-a" . imalison:align-regexp-hydra/body) | ||||
|   :config | ||||
|   (progn | ||||
| @@ -2242,9 +2237,10 @@ I don't use auto-complete at all, so I have set up a hook to automatically disab | ||||
| #+BEGIN_SRC emacs-lisp | ||||
|   (use-package flycheck | ||||
| 	:commands flycheck-mode | ||||
| 	:init (add-hook 'prog-mode-hook 'flycheck-mode) | ||||
|     :defer 1 | ||||
| 	:config | ||||
| 	(progn | ||||
|       (add-hook 'prog-mode-hook 'flycheck-mode) | ||||
| 	  (use-package flycheck-package | ||||
| 		:disabled t | ||||
| 		:config (flycheck-package-setup)) | ||||
| @@ -2261,12 +2257,6 @@ I don't use auto-complete at all, so I have set up a hook to automatically disab | ||||
| 	  (global-flycheck-mode)) | ||||
| 	:diminish flycheck-mode) | ||||
| #+END_SRC | ||||
| * straight | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package straight | ||||
|   :config | ||||
|   (setq straight-vc-git-auto-fast-forward t)) | ||||
| #+END_SRC | ||||
| * auth-source | ||||
| #+begin_src emacs-lisp | ||||
| (use-package auth-source | ||||
| @@ -2318,96 +2308,96 @@ I don't use auto-complete at all, so I have set up a hook to automatically disab | ||||
| #+END_SRC | ||||
| *** go | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package go-mode | ||||
|   :mode (("\\.go\\'" . go-mode)) | ||||
|   :preface | ||||
|   (progn | ||||
|     (defun imalison:glide-novendor () | ||||
|       (projectile-with-default-dir (projectile-project-root) | ||||
|         (shell-command-to-string "glide novendor"))) | ||||
| ;; (use-package go-mode | ||||
| ;;   :mode (("\\.go\\'" . go-mode)) | ||||
| ;;   :after emit | ||||
| ;;   :config | ||||
| ;;   (progn | ||||
| ;;     (defun imalison:glide-novendor () | ||||
| ;;       (projectile-with-default-dir (projectile-project-root) | ||||
| ;;         (shell-command-to-string "glide novendor"))) | ||||
|  | ||||
|     (defun imalison:go-mode-create-imenu-index () | ||||
|       "Create and return an imenu index alist. Unlike the default | ||||
|   alist created by go-mode, this method creates an alist where | ||||
|   items follow a style that is consistent with other prog-modes." | ||||
|       (let* ((patterns '(("type" "^type *\\([^ \t\n\r\f]*\\)" 1))) | ||||
|              (type-index (imenu--generic-function patterns)) | ||||
|              (func-index)) | ||||
|         (save-excursion | ||||
|           (goto-char (point-min)) | ||||
|           (while (re-search-forward go-func-meth-regexp (point-max) t) | ||||
|             (let* ((var (match-string-no-properties 1)) | ||||
|                    (func (match-string-no-properties 2)) | ||||
|                    (name (if var | ||||
|                              (concat (substring var 0 -1) "." func) | ||||
|                            func)) | ||||
|                    (beg (match-beginning 0)) | ||||
|                    (marker (copy-marker beg)) | ||||
|                    (item (cons name marker))) | ||||
|               (setq func-index (cons item func-index))))) | ||||
|         (nconc type-index (list (cons "func" func-index))))) | ||||
| ;;     (defun imalison:go-mode-create-imenu-index () | ||||
| ;;       "Create and return an imenu index alist. Unlike the default | ||||
| ;;   alist created by go-mode, this method creates an alist where | ||||
| ;;   items follow a style that is consistent with other prog-modes." | ||||
| ;;       (let* ((patterns '(("type" "^type *\\([^ \t\n\r\f]*\\)" 1))) | ||||
| ;;              (type-index (imenu--generic-function patterns)) | ||||
| ;;              (func-index)) | ||||
| ;;         (save-excursion | ||||
| ;;           (goto-char (point-min)) | ||||
| ;;           (while (re-search-forward go-func-meth-regexp (point-max) t) | ||||
| ;;             (let* ((var (match-string-no-properties 1)) | ||||
| ;;                    (func (match-string-no-properties 2)) | ||||
| ;;                    (name (if var | ||||
| ;;                              (concat (substring var 0 -1) "." func) | ||||
| ;;                            func)) | ||||
| ;;                    (beg (match-beginning 0)) | ||||
| ;;                    (marker (copy-marker beg)) | ||||
| ;;                    (item (cons name marker))) | ||||
| ;;               (setq func-index (cons item func-index))))) | ||||
| ;;         (nconc type-index (list (cons "func" func-index))))) | ||||
|  | ||||
|     (defun imalison:go-workspace-path () | ||||
|       (file-relative-name (projectile-project-root) | ||||
|                           (concat (file-name-as-directory | ||||
|                                    (imalison:get-go-path)) "src"))) | ||||
| ;;     (defun imalison:go-workspace-path () | ||||
| ;;       (file-relative-name (projectile-project-root) | ||||
| ;;                           (concat (file-name-as-directory | ||||
| ;;                                    (imalison:get-go-path)) "src"))) | ||||
|  | ||||
|     (defun imalison:install-current-go-project () | ||||
|       (interactive) | ||||
|       (start-process | ||||
|        "go install" "go install log" "go" "install" | ||||
|        (concat (file-name-as-directory (imalison:go-workspace-path)) "..."))) | ||||
| ;;     (defun imalison:install-current-go-project () | ||||
| ;;       (interactive) | ||||
| ;;       (start-process | ||||
| ;;        "go install" "go install log" "go" "install" | ||||
| ;;        (concat (file-name-as-directory (imalison:go-workspace-path)) "..."))) | ||||
|  | ||||
|     (defun imalison:get-go-path () | ||||
|       (let ((environment-go-path (getenv "GOPATH"))) | ||||
|         (if environment-go-path | ||||
|             (file-name-as-directory (car (s-split ":" environment-go-path))) | ||||
|           "~/go"))) | ||||
| ;;     (defun imalison:get-go-path () | ||||
| ;;       (let ((environment-go-path (getenv "GOPATH"))) | ||||
| ;;         (if environment-go-path | ||||
| ;;             (file-name-as-directory (car (s-split ":" environment-go-path))) | ||||
| ;;           "~/go"))) | ||||
|  | ||||
|     (defmacro imalison:get-go-src (&rest paths) | ||||
|       `(imalison:join-paths (imalison:get-go-path) "src" ,@paths)) | ||||
| ;;     (defmacro imalison:get-go-src (&rest paths) | ||||
| ;;       `(imalison:join-paths (imalison:get-go-path) "src" ,@paths)) | ||||
|  | ||||
|     (imalison:let-advise-around imalison:advise-normal-go-command | ||||
|       (go-command "go")) | ||||
| ;;     (imalison:let-advise-around imalison:advise-normal-go-command | ||||
| ;;       (go-command "go")) | ||||
|  | ||||
|     (defun imalison:go-mode-hook () | ||||
|       (go-eldoc-setup) | ||||
|       (set (make-local-variable 'company-backends) '(company-go)) | ||||
|       (make-local-variable 'projectile-globally-ignored-files) | ||||
|       (add-hook 'after-save-hook 'imalison:install-current-go-project nil | ||||
|                 'yes-do-local) | ||||
|       (add-to-list 'projectile-globally-ignored-files | ||||
|                    "vendor"))) | ||||
|   :config | ||||
|   (progn | ||||
|     (use-package gotest | ||||
|       :demand t | ||||
|       :bind (:map go-mode-map | ||||
|                   ("C-c t" . imalison:gotest)) | ||||
|       :preface | ||||
|       (progn | ||||
|         (emit-prefix-selector imalison:gotest | ||||
|           go-test-current-test | ||||
|           go-test-current-file) | ||||
| ;;     (defun imalison:go-mode-hook () | ||||
| ;;       (go-eldoc-setup) | ||||
| ;;       (set (make-local-variable 'company-backends) '(company-go)) | ||||
| ;;       (make-local-variable 'projectile-globally-ignored-files) | ||||
| ;;       (add-hook 'after-save-hook 'imalison:install-current-go-project nil | ||||
| ;;                 'yes-do-local) | ||||
| ;;       (add-to-list 'projectile-globally-ignored-files | ||||
| ;;                    "vendor")) | ||||
| ;;     (use-package gotest | ||||
| ;;       :demand t | ||||
| ;;       :after emit | ||||
| ;;       :bind (:map go-mode-map | ||||
| ;;                   ("C-c t" . imalison:gotest)) | ||||
| ;;       :preface | ||||
| ;;       (progn | ||||
| ;;         (emit-prefix-selector imalison:gotest | ||||
| ;;           go-test-current-test | ||||
| ;;           go-test-current-file) | ||||
|  | ||||
|         (defun imalison:add-expected-test-name-for-suite (suite-name test-name) | ||||
|           (if (> (length suite-name) 0) | ||||
|               (concat " -run Test" suite-name) | ||||
|             ""))) | ||||
|       :config | ||||
|       (progn | ||||
|         (setq go-test-verbose t | ||||
|               go-test-additional-arguments-function | ||||
|               'imalison:add-expected-test-name-for-suite))) | ||||
|     (use-package company-go | ||||
|       :config (setq company-go-show-annotation t)) | ||||
| ;;         (defun imalison:add-expected-test-name-for-suite (suite-name test-name) | ||||
| ;;           (if (> (length suite-name) 0) | ||||
| ;;               (concat " -run Test" suite-name) | ||||
| ;;             ""))) | ||||
| ;;       :config | ||||
| ;;       (progn | ||||
| ;;         (setq go-test-verbose t | ||||
| ;;               go-test-additional-arguments-function | ||||
| ;;               'imalison:add-expected-test-name-for-suite))) | ||||
| ;;     (use-package company-go | ||||
| ;;       :config (setq company-go-show-annotation t)) | ||||
|  | ||||
|     (advice-add 'go-import-add :around 'imalison:advise-normal-go-command) | ||||
| ;;     (advice-add 'go-import-add :around 'imalison:advise-normal-go-command) | ||||
|  | ||||
|     (setq gofmt-command "goimports") | ||||
| ;;     (setq gofmt-command "goimports") | ||||
|  | ||||
|     (add-hook 'go-mode-hook 'imalison:go-mode-hook) | ||||
|     (add-hook 'before-save-hook 'gofmt-before-save t))) | ||||
| ;;     (add-hook 'go-mode-hook 'imalison:go-mode-hook) | ||||
| ;;     (add-hook 'before-save-hook 'gofmt-before-save t))) | ||||
| #+END_SRC | ||||
| **** Show diffs of testify output | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| @@ -2449,13 +2439,25 @@ I don't use auto-complete at all, so I have set up a hook to automatically disab | ||||
| **** elisp-slime-nav | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package elisp-slime-nav | ||||
|   :after emit | ||||
|   :commands elisp-slime-nav-mode | ||||
|   :config | ||||
|   (progn | ||||
|     (defvar imalison:check-parens nil) | ||||
|  | ||||
|     (defun imalison:maybe-check-parens () | ||||
|       (if imalison:check-parens | ||||
|           (check-parens))) | ||||
|  | ||||
|     (defun imalison:emacs-lisp-hook () | ||||
|       (elisp-slime-nav-mode t) | ||||
|       (add-hook 'write-file-functions 'imalison:maybe-check-parens nil t)) | ||||
|  | ||||
|     (add-hook 'emacs-lisp-mode-hook 'imalison:emacs-lisp-hook) | ||||
|     (diminish 'elisp-slime-nav-mode) | ||||
|   :preface | ||||
|     (emit-prefix-selector imalison:elisp-slime-nav | ||||
|       elisp-slime-nav-find-elisp-thing-at-point | ||||
|     elisp-slime-nav-describe-elisp-thing-at-point) | ||||
|       elisp-slime-nav-describe-elisp-thing-at-point)) | ||||
|   :bind (:map elisp-slime-nav-mode-map | ||||
|               ("M-." . imalison:elisp-slime-nav))) | ||||
| #+END_SRC | ||||
| @@ -2465,6 +2467,7 @@ it's supposed to do, but instead uses its own collection of functions to control | ||||
| where the definition is popped up. This fixes that. | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package find-func | ||||
|   :ensure nil | ||||
|   :preface | ||||
|   (progn | ||||
|     (defun imalison:find-function-display-buffer (function) | ||||
| @@ -2484,14 +2487,6 @@ Macrostep is an indespensible tool for writing emacs lisp macros. It lets you se | ||||
|   :bind (:map lisp-mode-shared-map | ||||
|               ("C-c e" . macrostep-expand))) | ||||
| #+END_SRC | ||||
| **** emr | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package emr | ||||
|   :bind ("M-RET" . emr-show-refactor-menu) | ||||
|   :config | ||||
|   (progn | ||||
|     (add-hook 'prog-mode-hook 'emr-initialize))) | ||||
| #+END_SRC | ||||
| **** Editing configuration | ||||
| Reduce indentation for some functions | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| @@ -2505,6 +2500,7 @@ Reduce indentation for some functions | ||||
| **** edebug | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package edebug | ||||
|   :ensure nil | ||||
|   :defer t | ||||
|   :config | ||||
|   (progn (setq edebug-trace t))) | ||||
| @@ -2543,6 +2539,7 @@ Reduce indentation for some functions | ||||
|   :commands (eros-mode) | ||||
|   :config | ||||
|   (progn | ||||
|     (add-hook 'emacs-lisp-mode-hook 'eros-mode) | ||||
|     (advice-add 'eval-defun :around 'eros-around-eval-defun) | ||||
|     (advice-add 'eval-last-sexp :around 'eros-around-eval-last-sexp)) | ||||
|   :preface | ||||
| @@ -2563,9 +2560,7 @@ Reduce indentation for some functions | ||||
|            (save-excursion | ||||
|              (end-of-defun) | ||||
|              (point)))) | ||||
|         result)) | ||||
|  | ||||
|     (add-hook 'emacs-lisp-mode-hook 'eros-mode))) | ||||
|         result)))) | ||||
| #+END_SRC | ||||
| **** Reevalute defvars when running eval-last-sexp | ||||
| We noflet elisp--preceding-sexp to munge defvars into sexps only for | ||||
| @@ -2583,27 +2578,10 @@ eval-last-sexp. | ||||
| #+END_SRC | ||||
| **** Init hook | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (defvar imalison:check-parens nil) | ||||
|  | ||||
| (defun imalison:maybe-check-parens () | ||||
|   (if imalison:check-parens | ||||
|       (check-parens))) | ||||
|  | ||||
| (defun imalison:emacs-lisp-hook () | ||||
|   (elisp-slime-nav-mode t) | ||||
|   (add-hook 'write-file-functions 'imalison:maybe-check-parens nil t)) | ||||
|  | ||||
| (add-hook 'emacs-lisp-mode-hook 'imalison:emacs-lisp-hook) | ||||
| #+END_SRC | ||||
| **** Keybinds | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (emit-compose | ||||
|  imalison:copy-eval-last-sexp kill-new prin1-to-string eval-last-sexp) | ||||
|  | ||||
| (emit-prefix-selector imalison:eval-last-sexp | ||||
|   eval-region-or-last-sexp | ||||
|   imalison:copy-eval-last-sexp) | ||||
|  | ||||
| (define-key lisp-mode-shared-map (kbd "C-c C-c") 'eval-defun) | ||||
| (define-key lisp-mode-shared-map (kbd "C-x C-e") 'imalison:eval-last-sexp) | ||||
| (unbind-key "C-j" lisp-interaction-mode-map) | ||||
| @@ -2622,6 +2600,13 @@ eval-last-sexp. | ||||
|      (shell-command-to-string "nix eval -I \"$NIX_PATH\" --expr '<nixpkgs>' --impure")))) | ||||
|   :config | ||||
|   (progn | ||||
|     (use-package apheleia | ||||
|       :demand t | ||||
|       :config | ||||
|       (progn | ||||
|         (add-to-list 'apheleia-formatters '(alejandra . ("alejandra"))) | ||||
|         (setf (alist-get 'nix-mode apheleia-mode-alist) | ||||
|               '(alejandra)))) | ||||
|     (setq nix-indent-function 'nix-indent-line))) | ||||
|  | ||||
| (use-package lsp-nix | ||||
| @@ -2697,11 +2682,6 @@ The following is taken from [[https://github.com/syl20bnr/spacemacs/blob/a650877 | ||||
|           cider-preferred-build-tool "boot") | ||||
|     (add-hook 'clojure-mode-hook 'cider-mode))) | ||||
| #+END_SRC | ||||
| **** clj-refactor | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package clj-refactor | ||||
|   :commands clj-refactor-mode) | ||||
| #+END_SRC | ||||
| *** scala | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package scala-mode | ||||
| @@ -2885,6 +2865,10 @@ The following is taken from [[https://github.com/syl20bnr/spacemacs/blob/a650877 | ||||
|   :defer t | ||||
|   :mode ("\\.kt\\'")) | ||||
| #+END_SRC | ||||
| *** groovy | ||||
| #+begin_src emacs-lisp | ||||
| (use-package groovy-mode) | ||||
| #+end_src | ||||
| *** vala | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package vala-mode | ||||
| @@ -2897,7 +2881,7 @@ The following is taken from [[https://github.com/syl20bnr/spacemacs/blob/a650877 | ||||
| #+END_SRC | ||||
| *** C/C++ | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package cc-mode) | ||||
| (use-package cc-mode :ensure nil) | ||||
| #+END_SRC | ||||
| *** C-- | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| @@ -2931,6 +2915,10 @@ The following is taken from [[https://github.com/syl20bnr/spacemacs/blob/a650877 | ||||
| (use-package protobuf-mode | ||||
|   :defer t) | ||||
| #+END_SRC | ||||
| *** graphql | ||||
| #+begin_src emacs-lisp | ||||
| (use-package graphql-mode) | ||||
| #+end_src | ||||
| *** json-mode | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package json-mode | ||||
| @@ -2947,6 +2935,10 @@ The following is taken from [[https://github.com/syl20bnr/spacemacs/blob/a650877 | ||||
|   :mode (("\\.yaml\\'" . yaml-mode) | ||||
|          ("\\.yml\\'" . yaml-mode))) | ||||
| #+END_SRC | ||||
| *** just-mode | ||||
| #+begin_src emacs-lisp | ||||
| (use-package just-mode) | ||||
| #+end_src | ||||
| *** es-mode | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package es-mode | ||||
| @@ -2967,6 +2959,11 @@ The following is taken from [[https://github.com/syl20bnr/spacemacs/blob/a650877 | ||||
| (use-package toml-mode | ||||
|   :mode (("\\.toml\\'" . toml-mode))) | ||||
| #+end_src | ||||
| *** terraform | ||||
| #+begin_src emacs-lisp | ||||
| (use-package terraform-mode | ||||
|   :mode (("\\.tf\\'" . terraform-mode))) | ||||
| #+end_src | ||||
| ** Document | ||||
| *** org | ||||
| My org-mode configuration now lives in its own file org-config.org. | ||||
| @@ -3089,9 +3086,10 @@ My org-mode configuration now lives in its own file org-config.org. | ||||
| ** magit | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package magit | ||||
|   :after emit | ||||
|   :commands magit-status | ||||
|   :bind (("C-x g" . imalison:magit-status)) | ||||
|   :preface | ||||
|   :config | ||||
|   (progn | ||||
|     (emit-let-around imalison:magit-status-traditional | ||||
|                      magit-status | ||||
| @@ -3102,9 +3100,7 @@ My org-mode configuration now lives in its own file org-config.org. | ||||
|       imalison:magit-status-traditional) | ||||
|     (defun imalison:after-magit-visit-file (&rest args) | ||||
|       (when (derived-mode-p 'org-mode) | ||||
|         (org-show-context 'magit-goto)))) | ||||
|   :config | ||||
|   (progn | ||||
|         (org-show-context 'magit-goto))) | ||||
|     (when frame-mode | ||||
|       (setq magit-commit-show-diff t)) | ||||
|     (unbind-key "C-j" magit-status-mode-map) | ||||
| @@ -3115,7 +3111,6 @@ My org-mode configuration now lives in its own file org-config.org. | ||||
|           magit-display-buffer-function | ||||
|           'magit-display-buffer-same-window-except-diff-v1) | ||||
|     (magit-auto-revert-mode) | ||||
|  | ||||
|     (add-to-list 'org-show-context-detail '(magit-goto . lineage)) | ||||
|     (advice-add 'magit-diff-visit-file :after 'imalison:after-magit-visit-file) | ||||
|     (add-hook 'magit-popup-mode-hook 'imalison:disable-show-trailing-whitespace))) | ||||
| @@ -3126,27 +3121,27 @@ My org-mode configuration now lives in its own file org-config.org. | ||||
|   :disabled t | ||||
|   :after magit) | ||||
| #+end_src | ||||
| ** vc | ||||
| #+begin_src emacs-lisp | ||||
| (use-package vc | ||||
|   :config | ||||
|   (progn | ||||
|     (defun vc-find-revision-of-file (revision) | ||||
|       (interactive | ||||
|        (list (vc-read-revision | ||||
|               "Revision to visit: " | ||||
|               (list (imalison:join-paths (magit-toplevel) (car (magit-list-files))))))) | ||||
|       (let* ((file (completing-read "Select file to visit: " (magit-revision-files revision))) | ||||
|              (full-file (imalison:join-paths (magit-toplevel) file))) | ||||
|         (switch-to-buffer (vc-find-revision full-file revision)))))) | ||||
| #+end_src | ||||
| ** git-link | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package git-link | ||||
|   :defer t | ||||
|   :config | ||||
|   (progn | ||||
|     (setq git-link-use-commit t))) | ||||
|     (setq git-link-use-commit t) | ||||
|     (defun git-link-commit-gitea (hostname dirname commit) | ||||
|       (format "https://%s/%s/commit/%s" | ||||
| 	          hostname | ||||
| 	          dirname | ||||
| 	          commit)) | ||||
|     (defun git-link-gitea (hostname dirname filename branch commit start end) | ||||
|       (format "https://%s/%s/src/commit/%s/%s#L%s" | ||||
|               hostname | ||||
|               dirname | ||||
|               commit | ||||
|               filename | ||||
|               start)) | ||||
|     (add-to-list 'git-link-remote-alist '("dev.railbird.ai" git-link-gitea)) | ||||
|     (add-to-list 'git-link-commit-remote-alist '("dev.railbird.ai" git-link-gitea)))) | ||||
| #+END_SRC | ||||
| ** magit-gitflow | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| @@ -3250,14 +3245,6 @@ modeline and with excessive http requests to github. | ||||
|                          gist-unstar gist-list-starred gist-fork)) | ||||
| #+END_SRC | ||||
| * Programming | ||||
| ** emr | ||||
| emr (emacs refactor) provides support for refactoring in many programming languages | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package emr | ||||
|   :bind (:map prog-mode-map | ||||
|               ("M-RET" . emr-show-refactor-menu)) | ||||
|   :config (emr-initialize)) | ||||
| #+END_SRC | ||||
| ** semantic | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package semantic | ||||
| @@ -3269,10 +3256,15 @@ emr (emacs refactor) provides support for refactoring in many programming langua | ||||
| #+END_SRC | ||||
| ** language-server-protocol (lsp) | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (defvar imalison:use-lsp nil) | ||||
| (use-package lsp-mode | ||||
|   :defer 3 | ||||
|   :commands lsp | ||||
|   :preface | ||||
|   (defun imalison:lsp-deferred-when-enabled () | ||||
|     (add-hook 'hack-local-variables-hook | ||||
|               (lambda () | ||||
|                 (when imalison:use-lsp | ||||
|                   (lsp-deferred))) nil t)) | ||||
|   (defun imalison:nix-develop-lsp-wrapper-function (argv) | ||||
|     (append | ||||
|      (append (list "nix" "develop" "-I" "." "--impure" "--command") | ||||
| @@ -3283,10 +3275,34 @@ emr (emacs refactor) provides support for refactoring in many programming langua | ||||
|     (use-package lsp-ui | ||||
|       :config | ||||
|       (progn | ||||
|         (add-hook 'prog-mode-hook 'imalison:lsp-deferred-when-enabled) | ||||
|         (add-hook 'lsp-mode-hook 'lsp-ui-mode) | ||||
|         (setq lsp-ui-doc-position 'bottom))))) | ||||
| #+END_SRC | ||||
| * Utility | ||||
| ** eat | ||||
| #+begin_src emacs-lisp | ||||
| (use-package eat | ||||
|   :preface | ||||
|   (progn | ||||
|     (defun imalison:avy-eat (arg) | ||||
|       (interactive "P") | ||||
|       (eat-emacs-mode) | ||||
|       (imalison:avy arg))) | ||||
|   :bind | ||||
|   (:map eat-mode-map | ||||
|         ("C-c C-k" . eat-semi-char-mode) | ||||
|         :map eat-semi-char-mode-map | ||||
|         ("C-c C-j" . eat-emacs-mode) | ||||
|         ("C-j" . imalison:avy-eat)) | ||||
|   :config | ||||
|   (progn | ||||
|     (setq eat--install-path | ||||
|           (file-name-directory | ||||
|            (file-truename (imalison:join-paths eat--install-path "eat.el")))) | ||||
|     (eat-compile-terminfo) | ||||
|     (setq eat-term-shell-integration-directory (imalison:join-paths eat--install-path "integration")))) | ||||
| #+end_src | ||||
| ** term | ||||
| The main thing I do here is restore a bunch of keybindings that are eliminated | ||||
| in term-mode. This makes term-mode 1000% more useful | ||||
| @@ -3294,6 +3310,7 @@ in term-mode. This makes term-mode 1000% more useful | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package term | ||||
|   :demand t | ||||
|   :ensure nil | ||||
|   :preface | ||||
|   (progn | ||||
|     (defun imalison:avy-term (arg) | ||||
| @@ -3358,6 +3375,7 @@ in term-mode. This makes term-mode 1000% more useful | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package term-projectile | ||||
|   :bind ("C-c 7" . imalison:term-hydra-global/body) | ||||
|   :after emit | ||||
|   :commands | ||||
|   (term-projectile-backward | ||||
|    term-projectile-create-new | ||||
| @@ -3368,6 +3386,12 @@ in term-mode. This makes term-mode 1000% more useful | ||||
|    term-projectile-switch) | ||||
|   :config | ||||
|   (progn | ||||
|     (use-package term-manager-eat | ||||
|       :demand t | ||||
|       :straight | ||||
|       (term-manager-eat :type git :files ("term-manager-eat.el") | ||||
|                         :host github :repo "colonelpanic8/term-manager")) | ||||
|     (setq term-projectile-term-manager (term-projectile :build-term 'term-manager-eat-build-term)) | ||||
|     (emit-prefix-selector imalison:term | ||||
|       term-projectile-forward | ||||
|       term-projectile-create-new) | ||||
| @@ -3459,7 +3483,7 @@ crux-reopen-as-root-mode makes it so that any file owned by root will automatica | ||||
|   :config | ||||
|   (progn | ||||
|     (add-to-list 'gptel-directives '(finish-code . "You are a large language model and a careful programmer. Provide code that completes what is provided and only code as output without any additional text, prompt or note.")) | ||||
|     ;; (setq gptel-model "gpt-4") | ||||
|     (setq gptel-model "gpt-4") | ||||
|     )) | ||||
| #+end_src | ||||
| * Cooperation | ||||
| @@ -3523,6 +3547,7 @@ I don't use iedit directly, but it is used by [[*emr][emr]] and I need to disabl | ||||
| ** narrow-indirect | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package narrow-indirect | ||||
|   :ensure nil | ||||
|   :init | ||||
|   (progn | ||||
|     (define-key ctl-x-4-map "nd" 'ni-narrow-to-defun-indirect-other-window) | ||||
| @@ -3558,9 +3583,9 @@ I had to disable this mode because something that it does messes with coding set | ||||
|       (interactive) | ||||
|       (setq dtrt-indent-original-indent nil) | ||||
|       (dtrt-indent-adapt))) | ||||
|   :init (add-hook 'prog-mode-hook 'dtrt-indent-mode) | ||||
|   :config | ||||
|   (progn | ||||
|     (add-hook 'prog-mode-hook 'dtrt-indent-mode) | ||||
|     (setq dtrt-indent-active-mode-line-info " [⟼]"))) | ||||
| #+END_SRC | ||||
| ** indent-guide | ||||
| @@ -3601,7 +3626,9 @@ Disabled because it makes it hard to redo things | ||||
| ** recentf | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package recentf | ||||
|   :ensure nil | ||||
|   :demand t | ||||
|   :after shut-up | ||||
|   :config | ||||
|   (progn | ||||
|     (setq recentf-max-saved-items 1000 | ||||
| @@ -3697,6 +3724,7 @@ Not really sure what this is | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package epg | ||||
|   :after shut-up | ||||
|   :ensure nil | ||||
|   :config | ||||
|   (shut-up | ||||
|     (epa-file-enable))) | ||||
| @@ -3719,113 +3747,6 @@ Not really sure what this is | ||||
|   :disabled t ;; fails to load eieio on startup | ||||
|   ) | ||||
| #+END_SRC | ||||
| ** mu4e | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| ;; (eval-when-compile | ||||
| ;;   (require 's) | ||||
| ;;   (defvar mu4e-elisp-directory | ||||
| ;;     (s-trim (shell-command-to-string "mu4e_directory")))) | ||||
| (use-package mu4e | ||||
|   :disabled t | ||||
|   :load-path mu4e-elisp-directory | ||||
|   :straight nil | ||||
|   :commands (mu4e mu4e-view-message-with-msgid mu4e-update-index email) | ||||
|   :bind ("C-c 0" . email) | ||||
|   :config | ||||
|   (progn | ||||
|     (defun email (&optional arg) | ||||
|       (interactive "P") | ||||
|       (if (string-equal (persp-name persp-curr) "email") | ||||
|           (progn (delete-other-windows) (mu4e)) | ||||
|         (progn | ||||
|           (persp-switch "email") | ||||
|           (when (or (not (mu4e-running-p)) arg) | ||||
|             (delete-other-windows) (mu4e))))) | ||||
|     ;; enable inline images | ||||
|     (setq mu4e-view-show-images t) | ||||
|     ;; show images | ||||
|     (setq mu4e-show-images t) | ||||
|     ;; Try to display html as text | ||||
|     (setq mu4e-view-prefer-html nil) | ||||
|  | ||||
|     (setq mu4e-html2text-command "html2text -width 80 -nobs -utf8") | ||||
|  | ||||
|     ;; use imagemagick, if available | ||||
|     (when (fboundp 'imagemagick-register-types) | ||||
|       (imagemagick-register-types)) | ||||
|     (setq mail-user-agent 'mu4e-user-agent) | ||||
|     (require 'org-mu4e) | ||||
|     (setq mu4e-compose-complete-only-after nil) | ||||
|     (setq mu4e-maildir "~/Mail") | ||||
|  | ||||
|     (setq mu4e-drafts-folder "/[Gmail].Drafts") | ||||
|     (setq mu4e-sent-folder   "/[Gmail].Sent Mail") | ||||
|     (setq mu4e-trash-folder  "/[Gmail].Trash") | ||||
|  | ||||
|     (setq mu4e-sent-messages-behavior 'delete) | ||||
|     (setq mu4e-headers-skip-duplicates t) | ||||
|     (setq mu4e-update-interval (* 60 20)) | ||||
|     (setq message-kill-buffer-on-exit t) | ||||
|     (setq mail-user-agent 'mu4e-user-agent) ;; make mu4e the default mail client | ||||
|  | ||||
|     ;; don't save message to Sent Messages, Gmail/IMAP takes care of this | ||||
|     (setq mu4e-sent-messages-behavior 'delete) | ||||
|  | ||||
|     ;; allow for updating mail using 'U' in the main view: | ||||
|     (setq mu4e-get-mail-command "timeout 60 offlineimap") | ||||
|  | ||||
|     (add-hook 'mu4e-compose-mode-hook | ||||
|               (defun my-do-compose-stuff () (flyspell-mode))) | ||||
|  | ||||
|     (add-to-list 'mu4e-headers-actions '("view in browser" . mu4e-action-view-in-browser)) | ||||
|     (add-to-list 'mu4e-view-actions '("view in browser" . mu4e-action-view-in-browser)) | ||||
|  | ||||
|     (defun mu4e-view (msg headersbuf) | ||||
|       "Display the message MSG in a new buffer, and keep in sync with HDRSBUF. | ||||
|   'In sync' here means that moving to the next/previous message in | ||||
|   the the message view affects HDRSBUF, as does marking etc. | ||||
|  | ||||
|   As a side-effect, a message that is being viewed loses its 'unread' | ||||
|   marking if it still had that." | ||||
|       (let* ((embedded ;; is it as an embedded msg (ie. message/rfc822 att)? | ||||
|               (when (gethash (mu4e-message-field msg :path) | ||||
|                              mu4e~path-parent-docid-map) t)) | ||||
|              (buf | ||||
|               (if embedded | ||||
|                   (mu4e~view-embedded-winbuf) | ||||
|                 (get-buffer-create mu4e~view-buffer-name)))) | ||||
|         ;; note: mu4e~view-mark-as-read will pseudo-recursively call mu4e-view again | ||||
|         ;; by triggering mu4e~view again as it marks the message as read | ||||
|         (with-current-buffer buf | ||||
|           (switch-to-buffer buf) | ||||
|           (setq mu4e~view-msg msg) | ||||
|           ;;(or embedded (not (mu4e~view-mark-as-read msg))) | ||||
|           (when (or (mu4e~view-mark-as-read msg) t) | ||||
|             (let ((inhibit-read-only t)) | ||||
|               (erase-buffer) | ||||
|               (mu4e~delete-all-overlays) | ||||
|               (insert (mu4e-view-message-text msg)) | ||||
|               (goto-char (point-min)) | ||||
|               (mu4e~fontify-cited) | ||||
|               (mu4e~fontify-signature) | ||||
|               (mu4e~view-make-urls-clickable) | ||||
|               (mu4e~view-show-images-maybe msg) | ||||
|               (setq | ||||
|                mu4e~view-buffer buf | ||||
|                mu4e~view-headers-buffer headersbuf) | ||||
|               (when embedded (local-set-key "q" 'kill-buffer-and-window)) | ||||
|               (mu4e-view-mode)))))) | ||||
|  | ||||
|     (require 'smtpmail) | ||||
|  | ||||
|     ;; alternatively, for emacs-24 you can use: | ||||
|     (setq message-send-mail-function 'smtpmail-send-it | ||||
|           smtpmail-stream-type 'starttls | ||||
|           smtpmail-default-smtp-server "smtp.gmail.com" | ||||
|           smtpmail-smtp-server "smtp.gmail.com" | ||||
|           smtpmail-smtp-service 587))) | ||||
|  | ||||
| #+END_SRC | ||||
| ** gmail-message-mode | ||||
| This is useful with server mode when editing gmail messages. I think that it is not currently working, or it may need to be manually enabled. | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| @@ -3860,56 +3781,6 @@ This is useful with server mode when editing gmail messages. I think that it is | ||||
|        :notifier 'imalison:windows-toast-notify) | ||||
|       (setq alert-default-style 'windows-toast)))) | ||||
| #+END_SRC | ||||
| ** sauron | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package sauron | ||||
|   :disabled t | ||||
|   :defer 5 | ||||
|   :commands (sauron-start sauron-start-hidden) | ||||
|   :init | ||||
|   (progn | ||||
|     (when (eq system-type 'darwin) | ||||
|       (setq sauron-modules '(sauron-erc sauron-org sauron-notifications | ||||
|                                         sauron-twittering sauron-jabber sauron-identica)) | ||||
|       (defun sauron-dbus-start () | ||||
|         nil) | ||||
|       (makunbound 'dbus-path-emacs))) | ||||
|   :config | ||||
|   (progn | ||||
|     (sauron-start-hidden) | ||||
|     ;; This should really check (featurep 'dbus) but for some reason | ||||
|     ;; this is always true even if support is not there. | ||||
|     (setq sauron-prio-sauron-started 2) | ||||
|     (setq sauron-min-priority 3) | ||||
|     ;; (setq sauron-dbus-cookie t) ;; linux only? | ||||
|     (setq sauron-separate-frame nil) | ||||
|     (setq sauron-nick-insensitivity 1) | ||||
|     (defun sauron:jabber-notify (origin priority message &optional properties) | ||||
|       (funcall notify-function "gtalk" message)) | ||||
|     (defun sauron:erc-notify (origin priority message &optional properties) | ||||
|       (let ((event (plist-get properties :event))) | ||||
|         (funcall notify-function "IRC" message))) | ||||
|     (defun sauron:mu4e-notify (origin priority message &optional properties) | ||||
|       nil) | ||||
|     (defun sauron:dbus-notify (origin priority message &optional properties) | ||||
|       (funcall notify-function "GMail" message)) | ||||
|     (defun sauron:dispatch-notify (origin priority message &optional properties) | ||||
|       (let ((handler (cond ((string= origin "erc") 'sauron:erc-notify) | ||||
|                            ((string= origin "jabber") 'sauron:jabber-notify) | ||||
|                            ((string= origin "mu4e") 'sauron:mu4e-notify) | ||||
|                            ((string= origin "dbus") 'sauron:dbus-notify) | ||||
|                            (t (lambda (&rest r) nil))))) | ||||
|         (funcall handler origin priority message properties))) | ||||
|     ;; Prefering alert.el for now ;; (add-hook 'sauron-event-added-functions 'sauron:dispatch-notify) | ||||
|     (sauron-start-hidden) | ||||
|     (add-hook 'sauron-event-added-functions 'sauron-alert-el-adapter))) | ||||
|  | ||||
| #+END_SRC | ||||
| ** screenshot | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package screenshot | ||||
|   :commands screenshot) | ||||
| #+END_SRC | ||||
| ** libmpdee | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package libmpdee | ||||
| @@ -4040,23 +3911,24 @@ This also adds syntax highlighting for gradle | ||||
| ** jsx-mode | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package jsx-mode | ||||
|   :ensure nil | ||||
|   :defer t) | ||||
| #+END_SRC | ||||
| ** css | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package css-mode | ||||
|   :ensure nil | ||||
|   :mode (("\\.css\\'" . css-mode) | ||||
|          ("\\.rasi\\'" . css-mode))) | ||||
| #+END_SRC | ||||
| ** sgml-mode | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package sgml-mode | ||||
|   ;; :bind ("C-c b" . web-beautify-html) TODO: mode specific, change binding | ||||
|   :commands sgml-mode) | ||||
| #+END_SRC | ||||
| ** evil | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| (use-package evil :commands (evil-mode)) | ||||
| (use-package evil | ||||
|   :commands (evil-mode) | ||||
|   :config | ||||
|   (use-package evil-collection | ||||
|     :config | ||||
|     (with-eval-after-load 'eat (evil-collection-eat-setup)))) | ||||
| #+END_SRC | ||||
| ** hackernews | ||||
| #+BEGIN_SRC emacs-lisp | ||||
| @@ -4077,6 +3949,9 @@ Ensure all themes that I use are installed: | ||||
|   (progn | ||||
|     (setq solarized-high-contrast-mode-line t))) | ||||
|  | ||||
| (defun elpaca-function (pkg) | ||||
|   (eval `(elpaca ,pkg))) | ||||
|  | ||||
| (defvar-setq packages-appearance | ||||
|   '(monokai-theme zenburn-theme base16-theme molokai-theme moe-theme | ||||
|                   tango-2-theme gotham-theme sublime-themes rainbow-delimiters | ||||
| @@ -4085,7 +3960,7 @@ Ensure all themes that I use are installed: | ||||
|                   forest-blue-theme flatland-theme afternoon-theme | ||||
|                   cyberpunk-theme dracula-theme)) | ||||
|  | ||||
| (mapcar 'straight-use-package packages-appearance) | ||||
| (mapcar 'elpaca-function packages-appearance) | ||||
|  | ||||
| (use-package doom-themes | ||||
|   :defer t) | ||||
| @@ -4240,14 +4115,15 @@ load-theme hook (See the heading below). | ||||
|   (unless imalison:appearance-setup-done | ||||
|     (unless (member imalison:dark-theme custom-enabled-themes) | ||||
|       (load-theme imalison:dark-theme t)) | ||||
|     (doom-modeline-mode +1) | ||||
|     (apply 'imalison:appearance args) | ||||
|     (message "running appearance") | ||||
|     (doom-modeline-mode +1) | ||||
|     (setq imalison:default-font-size-pt (face-attribute 'default :height)) | ||||
|     (setq imalison:appearance-setup-done t))) | ||||
|  | ||||
| (add-hook 'after-make-frame-functions 'imalison:appearance-setup-hook) | ||||
| (add-hook 'after-init-hook 'imalison:appearance-setup-hook) | ||||
| (add-hook 'elpaca-after-init-hook | ||||
|           (lambda () (add-hook 'after-make-frame-functions 'imalison:appearance-setup-hook))) | ||||
| (add-hook 'elpaca-after-init-hook 'imalison:appearance-setup-hook) | ||||
| #+END_SRC | ||||
| * Post Init Custom | ||||
| #+BEGIN_SRC emacs-lisp | ||||
|   | ||||
| @@ -1,41 +1,28 @@ | ||||
| ;; -*- no-byte-compile: t -*- | ||||
|  | ||||
| (let ((bootstrap-file (concat user-emacs-directory "straight/bootstrap.el")) | ||||
|       (bootstrap-version 2)) | ||||
|   (unless (file-exists-p bootstrap-file) | ||||
|     (with-current-buffer | ||||
|         (url-retrieve-synchronously | ||||
|          "https://raw.githubusercontent.com/raxod502/straight.el/develop/install.el" | ||||
|          'silent 'inhibit-cookies) | ||||
|       (goto-char (point-max)) | ||||
|       (eval-print-last-sexp))) | ||||
|   (load bootstrap-file nil 'nomessage)) | ||||
|  | ||||
| (setq native-comp-deferred-compilation-deny-list '("magit")) | ||||
| (setq native-comp-always-compile t) | ||||
| (setq load-no-native t) | ||||
| (setq no-native-compile t) | ||||
| (setq warning-minimum-level :emergency) | ||||
| (setq straight-disable-native-compile t) | ||||
|  | ||||
| ;; This is a workaround for an issue in emacs28 with symlinks. See https://github.com/radian-software/straight.el/issues/701 | ||||
| (defun my-patch-package-find-file-visit-truename (oldfun &rest r) | ||||
|   (let ((find-file-visit-truename nil)) | ||||
|     (apply oldfun r))) | ||||
|  | ||||
| (advice-add #'straight--build-autoloads :around | ||||
|             #'my-patch-package-find-file-visit-truename) | ||||
|  | ||||
| (setq package-enable-at-startup nil | ||||
|       straight-use-package-by-default t | ||||
|       straight-vc-git-default-protocol 'ssh) | ||||
| (straight-use-package 'use-package) | ||||
|  | ||||
| (require 'use-package) | ||||
| (setq use-package-enable-imenu-support t) | ||||
| (setq use-package-ensure-function 'straight-use-package-ensure-function) | ||||
| (setq use-package-always-ensure t) | ||||
|  | ||||
| (defvar imalison:do-benchmark nil) | ||||
|  | ||||
| (defun emacs-directory-filepath (filename) | ||||
|   (concat (file-name-directory load-file-name) filename)) | ||||
|  | ||||
| (load (emacs-directory-filepath "elpaca.el")) | ||||
|  | ||||
| (setq use-package-always-ensure t) | ||||
|  | ||||
| (let ((bench-file (concat (file-name-directory user-init-file) "benchmark.el"))) | ||||
|   (when (file-exists-p bench-file) (load bench-file))) | ||||
|  | ||||
| @@ -55,6 +42,9 @@ | ||||
|   (setq mac-option-modifier 'meta) | ||||
|   (setq mac-command-modifier 'super)) | ||||
|  | ||||
| (use-package transient | ||||
|   :demand t) | ||||
|  | ||||
| ;; See https://github.com/magit/magit/discussions/4997 . Without this magit is broken. | ||||
| (use-package magit | ||||
|   :demand t) | ||||
| @@ -62,29 +52,56 @@ | ||||
| ;; This seems to fix issues with helm not explicitly declaring its dependency on async | ||||
| (use-package async :demand t) | ||||
|  | ||||
| (use-package s :demand t) | ||||
|  | ||||
| ;; Without this, org can behave very strangely | ||||
| (use-package org | ||||
|   :straight | ||||
|   :ensure | ||||
|   (org :type git :host github :repo "colonelpanic8/org-mode" :local-repo "org" | ||||
|        :branch "my-main" | ||||
|        :depth full :pre-build (straight-recipes-org-elpa--build) :build | ||||
|        :depth full | ||||
| 	   :build | ||||
|        :wait t | ||||
|        (:not autoloads) :files | ||||
|        (:defaults "lisp/*.el" ("etc/styles/" "etc/styles/*"))) | ||||
|   :defer t) | ||||
|        (:defaults "lisp/*.el" ("etc/styles/" "etc/styles/*")))) | ||||
|  | ||||
| (use-package dash :demand t) | ||||
|  | ||||
| (use-package emit | ||||
|   :ensure (emit :type git :host github :repo "colonelpanic8/emit") | ||||
|   :demand t | ||||
|   :config | ||||
|   (progn | ||||
|     (emit-prefix-selector imalison:mark-ring mark-ring) | ||||
|     (emit-prefix-selector imalison:shell-command-on-region | ||||
|       imalison:copy-shell-command-on-region | ||||
|       imalison:shell-command-on-region-replace | ||||
|       imalison:jq-replace) | ||||
|  | ||||
|     (defun imalison:jq-replace (start end) | ||||
|       (interactive (region-if-active-otherwise-buffer)) | ||||
|       (imalison:shell-command-on-region-replace start end "jq .")) | ||||
|     (emit-compose | ||||
|       imalison:copy-eval-last-sexp kill-new prin1-to-string eval-last-sexp) | ||||
|  | ||||
|     (emit-prefix-selector imalison:eval-last-sexp | ||||
|       eval-region-or-last-sexp | ||||
|       imalison:copy-eval-last-sexp))) | ||||
|  | ||||
| (use-package s | ||||
|   :ensure (:inherit t :wait t) | ||||
|   :config | ||||
|   (when (or (equal (s-trim (shell-command-to-string "whoami")) "kat") | ||||
|             imalison:kat-mode) | ||||
|     (let ((debug-on-error t)) | ||||
|       (org-babel-load-file | ||||
|        (concat (file-name-directory load-file-name) "kat-mode.org"))))) | ||||
|  | ||||
| (let ((debug-on-error t)) | ||||
|   (org-babel-load-file | ||||
|    (concat (file-name-directory load-file-name) "README.org"))) | ||||
|  | ||||
| (when (or (equal (s-trim (shell-command-to-string "whoami")) "kat") | ||||
|           imalison:kat-mode) | ||||
|   (let ((debug-on-error t)) | ||||
|     (org-babel-load-file | ||||
|      (concat (file-name-directory load-file-name) "kat-mode.org")))) | ||||
|  | ||||
| (when imalison:do-benchmark (benchmark-init/deactivate)) | ||||
| ;; (when imalison:do-benchmark (benchmark-init/deactivate)) | ||||
|  | ||||
| ;; Local Variables: | ||||
| ;; flycheck-disabled-checkers: (emacs-lisp-checkdoc) | ||||
|   | ||||
| @@ -157,3 +157,14 @@ This makes evil-mode play nice with org-fc | ||||
|     (setf (alist-get 'python-ts-mode apheleia-mode-alist) | ||||
|           (alist-get 'python-mode apheleia-mode-alist)))) | ||||
| #+end_src | ||||
|  | ||||
| * Packages | ||||
| #+begin_src emacs-lisp | ||||
| (use-package org-drill) | ||||
|  | ||||
| #+end_src | ||||
|  | ||||
| * Disable wild notifactions | ||||
| #+begin_src emacs-lisp | ||||
| (setq org-wild-notifier-day-wide-alert-times nil) | ||||
| #+end_src | ||||
|   | ||||
| @@ -803,7 +803,7 @@ alphanumeric characters only." | ||||
| ** Use org-tempo to allow inserting templates using e.g. <s | ||||
| #+begin_src emacs-lisp | ||||
| (use-package org-tempo | ||||
|   :straight nil | ||||
|   :ensure nil | ||||
|   :after org) | ||||
| #+end_src | ||||
| * Packages | ||||
| @@ -938,9 +938,6 @@ alphanumeric characters only." | ||||
| #+end_src | ||||
| ***** ui | ||||
| #+begin_src emacs-lisp | ||||
| (use-package emacs-http-server | ||||
|   :demand t) | ||||
|  | ||||
| (use-package org-roam-ui | ||||
|   :after org-roam | ||||
|   :custom | ||||
|   | ||||
							
								
								
									
										5
									
								
								dotfiles/emacs.d/snippets/python-mode/ign
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								dotfiles/emacs.d/snippets/python-mode/ign
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| # -*- mode: snippet -*- | ||||
| # name: ign | ||||
| # key: ign | ||||
| # -- | ||||
| # type: ignore | ||||
							
								
								
									
										5
									
								
								dotfiles/emacs.d/snippets/python-mode/logg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								dotfiles/emacs.d/snippets/python-mode/logg
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| # -*- mode: snippet -*- | ||||
| # name: logg | ||||
| # key: logg | ||||
| # -- | ||||
| logger = logging.getLogger(__name__) | ||||
							
								
								
									
										5
									
								
								dotfiles/emacs.d/snippets/python-mode/noqa
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								dotfiles/emacs.d/snippets/python-mode/noqa
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| # -*- mode: snippet -*- | ||||
| # name: 401 | ||||
| # key: 401 | ||||
| # -- | ||||
| # noqa: F401 | ||||
| @@ -10,7 +10,7 @@ | ||||
| 	cpr = cherry-pick-range | ||||
| 	cam = commit -am | ||||
| 	clean-branches = "!r() { git branch --merged ${1-origin/master} | grep -v '*' | xargs -n1 git branch -d; }; r" | ||||
| 	del-merged-branches = "!f() { git fetch $1 && git branch -r --merged $1/$2 | awk -F/ \"/$1/ && !/$2$/ {print \\$2}\" | xargs -I {} git push $1 --delete {}; }; f" | ||||
| 	del-merged-branches = "!f() { git fetch $1 && git branch -r --merged $1/$2 | grep -v \"$1/$2$\" | sed \"s:$1/::\" | xargs -I {} sh -c \"git push $1 :{}\" _; }; f" | ||||
| 	clone = clone --recursive | ||||
| 	credit = "!f() { git commit --amend --author \"$1 <$2>\" -C HEAD; }; f" # Credit an author on the latest commit | ||||
| 	co = checkout | ||||
| @@ -50,6 +50,7 @@ | ||||
| 	tb = rev-parse --abbrev-ref --symbolic-full-name @{u} | ||||
| 	untracked = "!u() { git status -s | grep "??" | awk '{print $2}'; }; u" | ||||
| 	which-branch = "!wb() { b="$(git symbolic-ref HEAD)" && echo ${b#refs/heads/}; }; wb" | ||||
| 	find-merge = "!sh -c 'commit=$0 && branch=${1:-HEAD} && (git rev-list $commit..$branch --ancestry-path | cat -n; git rev-list $commit..$branch --first-parent | cat -n) | sort -k2 -s | uniq -f1 -d | sort -n | tail -1 | cut -f2'" | ||||
|  | ||||
| [core] | ||||
| 	# Use custom `.gitignore` and `.gitattributes` | ||||
| @@ -88,12 +89,6 @@ | ||||
| [rerere] | ||||
| 	enabled = false | ||||
|  | ||||
| [url "ssh://git@github.com/uber/"] | ||||
| 	insteadOf = https://github.com/uber/ | ||||
|  | ||||
| [url "ssh://gitolite@code.uber.internal:2222/"] | ||||
| 	insteadOf = https://code.uber.internal/ | ||||
|  | ||||
| [branch] | ||||
| 	autosetuprebase = always | ||||
|  | ||||
|   | ||||
| @@ -75,3 +75,7 @@ cabal.project.local | ||||
| # | ||||
| .direnv | ||||
| /dotfiles/config/gtk-3.0/settings.ini | ||||
|  | ||||
| /untracked | ||||
|  | ||||
| railbird-infra-*.json | ||||
|   | ||||
| @@ -6,6 +6,12 @@ import sys | ||||
|  | ||||
| class BrightnessManager(object): | ||||
|  | ||||
|     @classmethod | ||||
|     def find_brightness(cls): | ||||
|         return cls.from_path( | ||||
|             os.path.join("/sys/class/backlight", os.listdir("/sys/class/backlight")[0]) | ||||
|         ) | ||||
|  | ||||
|     @classmethod | ||||
|     def from_path(cls, path): | ||||
|         return cls( | ||||
| @@ -46,11 +52,6 @@ class BrightnessManager(object): | ||||
|         return float(self.current_brightness) / self.max_brightness | ||||
|  | ||||
|  | ||||
| IntelBrightnessManager = BrightnessManager.from_path( | ||||
|     "/sys/class/backlight/intel_backlight", | ||||
| ) | ||||
|  | ||||
|  | ||||
| def build_parser(): | ||||
|     parser = argparse.ArgumentParser( | ||||
|         description='Interact with macbook brightness', | ||||
| @@ -70,6 +71,6 @@ def build_parser(): | ||||
|  | ||||
| if __name__ == '__main__': | ||||
|     args = build_parser().parse_args() | ||||
|     IntelBrightnessManager.increment_by_proportion(float(args.change) / 100) | ||||
|     BrightnessManager.find_brightness().increment_by_proportion(float(args.change) / 100) | ||||
|     if args.do_print: | ||||
|         print(int(IntelBrightnessManager.current_proportion * 100)) | ||||
|   | ||||
							
								
								
									
										7
									
								
								dotfiles/lib/functions/nr
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										7
									
								
								dotfiles/lib/functions/nr
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| #!/usr/bin/env sh | ||||
|  | ||||
| function nr { | ||||
|     nix run nixpkgs#"$@" | ||||
| } | ||||
|  | ||||
| nr "$@" | ||||
| @@ -10,5 +10,3 @@ function split_by_char { | ||||
| } | ||||
|  | ||||
| split_by_char "$@" | ||||
|  | ||||
|  | ||||
|   | ||||
							
								
								
									
										7
									
								
								dotfiles/xkb/keymap/strixi-minaj
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								dotfiles/xkb/keymap/strixi-minaj
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| xkb_keymap { | ||||
| 	xkb_keycodes  { include "evdev+aliases(qwerty)"	}; | ||||
| 	xkb_types     { include "complete"	}; | ||||
| 	xkb_compat    { include "complete"	}; | ||||
| 	xkb_symbols   { include "pc+us+inet(evdev)+altwin(swap_lalt_lwin)+imalison(ralt_as_hyper)+capslock(ctrl_modifier)"	}; | ||||
| 	xkb_geometry  { include "pc(pc105)"	}; | ||||
| }; | ||||
| @@ -1,10 +1,12 @@ | ||||
| { config, pkgs, options, inputs, makeEnable, ... }: | ||||
| { config, pkgs, forEachUser, makeEnable, realUsers, ... }: | ||||
| makeEnable config "modules.base" true { | ||||
|   nixpkgs.config.permittedInsecurePackages = [ | ||||
|     "openssl-1.0.2u" | ||||
|     "electron-12.2.3" | ||||
|     "etcher" | ||||
|     "electron-19.1.9" | ||||
|     "openssl-1.1.1w" | ||||
|     "nix-2.16.2" | ||||
|   ]; | ||||
|  | ||||
|   # Disabling these waits disables the stuck on boot up issue | ||||
| @@ -18,7 +20,6 @@ makeEnable config "modules.base" true { | ||||
|       enable = true; | ||||
|       enableSSHSupport = true; | ||||
|     }; | ||||
|     package = pkgs.gnupg_2_4_0; | ||||
|   }; | ||||
|   services.pcscd.enable = true; | ||||
|  | ||||
| @@ -32,10 +33,6 @@ makeEnable config "modules.base" true { | ||||
|     enable = true; | ||||
|     enableStrongSwan = true; | ||||
|     plugins = [ pkgs.networkmanager-l2tp pkgs.networkmanager-openvpn ]; | ||||
|     extraConfig = '' | ||||
|       [main] | ||||
|       rc-manager=resolvconf | ||||
|     ''; | ||||
|   }; | ||||
|  | ||||
|   # Audio | ||||
| @@ -72,4 +69,7 @@ makeEnable config "modules.base" true { | ||||
|   services.dbus.packages = [ pkgs.gcr ]; | ||||
|  | ||||
|   programs.dconf.enable = true; | ||||
|  | ||||
|   home-manager.users = forEachUser (import ./home-manager.nix); | ||||
|   nix.settings.trusted-users = realUsers; | ||||
| } | ||||
|   | ||||
							
								
								
									
										18
									
								
								nixos/ben.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								nixos/ben.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| { pkgs, inputs, config, makeEnable, ... }: | ||||
| makeEnable config "modules.ben" true { | ||||
|   home-manager.backupFileExtension = "backup"; # Add this line | ||||
|   home-manager.users.ben = { | ||||
|     programs.zsh = { | ||||
|       enable = true; | ||||
|       shellAliases = { | ||||
|         l = "ls -CF"; | ||||
|         la = "ls -A"; | ||||
|         ll = "ls -lh"; | ||||
|         lla = "ls -alh"; | ||||
|         ls = "ls --color=auto"; | ||||
|         gts = "git status"; | ||||
|         gtl = "git log"; | ||||
|       }; | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
| @@ -98,7 +98,7 @@ | ||||
|           inherit inputs machineNames; | ||||
|           makeEnable = (import ../make-enable.nix) nixpkgs.lib; | ||||
|           mapValueToKeys = keys: value: builtins.listToAttrs (map (name: { inherit name value; }) keys); | ||||
|           realUsers = [ "root" "imalison" "kat" "dean" "alex" ]; | ||||
|           realUsers = [ "root" "imalison" "kat" "dean" "alex" "ben"]; | ||||
|           forEachUser = mapValueToKeys realUsers; | ||||
|         } // specialArgs // (import ../keys.nix); | ||||
|       }); | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| { config, makeEnable, lib, ... }: | ||||
| { config, lib, ... }: | ||||
| with lib; | ||||
| let cfg = config.modules.cache-server; | ||||
| in | ||||
| @@ -8,7 +8,7 @@ in | ||||
|       enable = mkEnableOption "nix cache server"; | ||||
|       port = mkOption { | ||||
|         type = types.int; | ||||
|         default = 8080; | ||||
|         default = 5050; | ||||
|       }; | ||||
|       host-string = mkOption { | ||||
|         type = types.string; | ||||
| @@ -27,18 +27,7 @@ in | ||||
|     services.nix-serve = { | ||||
|       enable = true; | ||||
|       secretKeyFile = config.age.secrets."cache-priv-key.pem".path; | ||||
|       port = 5050; | ||||
|     }; | ||||
|  | ||||
|     services.nginx = { | ||||
|       enable = true; | ||||
|       recommendedProxySettings = true; | ||||
|       virtualHosts = { | ||||
|         "${cfg.host-string}" = { | ||||
|           locations."${cfg.path}".proxyPass = "http://${config.services.nix-serve.bindAddress}:${toString config.services.nix-serve.port}"; | ||||
|           listen = [ { addr = "0.0.0.0"; port = cfg.port; } ]; | ||||
|         }; | ||||
|       }; | ||||
|       port = cfg.port; | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
|   | ||||
| @@ -57,6 +57,7 @@ makeEnable config "modules.code" true { | ||||
|     # nix | ||||
|     nixd | ||||
|     nil | ||||
|     alejandra | ||||
|   ] ++ (if pkgs.system == "x86_64-linux" then with pkgs; [ | ||||
|     # purescript | ||||
|     purescript | ||||
|   | ||||
| @@ -1,12 +1,14 @@ | ||||
| { config, lib, ... }: | ||||
| { config, lib, forEachUser, ... }: | ||||
| { | ||||
|   imports = [ | ||||
|     ./android.nix | ||||
|     ./base.nix | ||||
|     ./ben.nix | ||||
|     ./cache-server.nix | ||||
|     ./cache.nix | ||||
|     ./code.nix | ||||
|     ./desktop.nix | ||||
|     ./electron.nix | ||||
|     ./environment.nix | ||||
|     ./essential.nix | ||||
|     ./extra.nix | ||||
| @@ -23,10 +25,14 @@ | ||||
|     ./nixified.ai.nix | ||||
|     ./options.nix | ||||
|     ./plasma.nix | ||||
|     ./postgres.nix | ||||
|     ./rabbitmq.nix | ||||
|     ./secrets.nix | ||||
|     ./ssh.nix | ||||
|     ./syncthing.nix | ||||
|     ./user-specific.nix | ||||
|     ./users.nix | ||||
|     ./vscode.nix | ||||
|     ./wsl.nix | ||||
|     ./xmonad.nix | ||||
|   ]; | ||||
| @@ -42,6 +48,7 @@ | ||||
|     modules.gnome.enable = false; | ||||
|     modules.xmonad.enable = true; | ||||
|     modules.extra.enable = true; | ||||
|     modules.electron.enable = true; | ||||
|     modules.code.enable = true; | ||||
|     modules.games.enable = true; | ||||
|     modules.syncthing.enable = true; | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| { config, pkgs, makeEnable, forEachUser, ... }: | ||||
| { config, pkgs, makeEnable, ... }: | ||||
| makeEnable config "modules.desktop" true { | ||||
|   imports = [ | ||||
|     ./fonts.nix | ||||
| @@ -7,7 +7,9 @@ makeEnable config "modules.desktop" true { | ||||
|   services.xserver = { | ||||
|     exportConfiguration = true; | ||||
|     enable = true; | ||||
|     xkb = { | ||||
|       layout = "us"; | ||||
|     }; | ||||
|     displayManager = { | ||||
|       sessionCommands = '' | ||||
|         systemctl --user import-environment GDK_PIXBUF_MODULE_FILE DBUS_SESSION_BUS_ADDRESS PATH | ||||
| @@ -35,7 +37,7 @@ makeEnable config "modules.desktop" true { | ||||
|     gnome.adwaita-icon-theme | ||||
|     hicolor-icon-theme | ||||
|     libsForQt5.breeze-gtk | ||||
|     materia-theme | ||||
|     # materia-theme | ||||
|     numix-icon-theme-circle | ||||
|     papirus-icon-theme | ||||
|  | ||||
| @@ -53,18 +55,15 @@ makeEnable config "modules.desktop" true { | ||||
|     alacritty | ||||
|     blueman | ||||
|     clipit | ||||
|     dfeet | ||||
|     d-spy | ||||
|     dolphin | ||||
|     element-desktop | ||||
|  | ||||
|     feh | ||||
|     firefox | ||||
|     gnome.cheese | ||||
|     gnome.gpaste | ||||
|  | ||||
|     kleopatra | ||||
|     libnotify | ||||
|     # Seems to be broken | ||||
|     libreoffice | ||||
|     lxappearance | ||||
|     lxqt.lxqt-powermanagement | ||||
| @@ -98,35 +97,13 @@ makeEnable config "modules.desktop" true { | ||||
|     graphviz | ||||
|     nodePackages.mermaid-cli | ||||
|   ] ++ (if pkgs.system == "x86_64-linux" then with pkgs; [ | ||||
|     bitwarden | ||||
|     discord | ||||
|     etcher | ||||
|     google-chrome | ||||
|     keybase-gui | ||||
|     pommed_light | ||||
|     slack | ||||
|     spicetify-cli | ||||
|     spotify | ||||
|     tor-browser-bundle-bin | ||||
|     vscode | ||||
|     zoom-us | ||||
|     zulip | ||||
|   ] else []); | ||||
|  | ||||
|   home-manager.users = forEachUser (if pkgs.system == "x86_64-linux" then { | ||||
|     systemd.user.services.bitwarden = { | ||||
|       Unit = { | ||||
|         Description = "Bitwarden"; | ||||
|         After = [ "graphical-session-pre.target" "tray.target" ]; | ||||
|         PartOf = [ "graphical-session.target" ]; | ||||
|       }; | ||||
|  | ||||
|       Install = { WantedBy = [ "graphical-session.target" ]; }; | ||||
|  | ||||
|       Service = { | ||||
|         ExecStart = "${pkgs.bitwarden}/bin/bitwarden"; | ||||
|         Restart = "always"; | ||||
|         RestartSec = 3; | ||||
|       }; | ||||
|     }; | ||||
|   } else {}); | ||||
| } | ||||
|   | ||||
							
								
								
									
										28
									
								
								nixos/electron.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								nixos/electron.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | ||||
| { pkgs, config, makeEnable, forEachUser, ... }: | ||||
| makeEnable config "modules.electron" false { | ||||
|   environment.systemPackages = with pkgs; [ | ||||
|     element-desktop | ||||
|     # bitwarden | ||||
|     discord | ||||
|     # etcher | ||||
|     # keybase-gui | ||||
|     zoom-us | ||||
|   ]; | ||||
|   home-manager.users = forEachUser (if pkgs.system == "x86_64-linux" then { | ||||
|     # systemd.user.services.bitwarden = { | ||||
|     #   Unit = { | ||||
|     #     Description = "Bitwarden"; | ||||
|     #     After = [ "graphical-session-pre.target" "tray.target" ]; | ||||
|     #     PartOf = [ "graphical-session.target" ]; | ||||
|     #   }; | ||||
|  | ||||
|     #   Install = { WantedBy = [ "graphical-session.target" ]; }; | ||||
|  | ||||
|     #   Service = { | ||||
|     #     ExecStart = "${pkgs.bitwarden}/bin/bitwarden"; | ||||
|     #     Restart = "always"; | ||||
|     #     RestartSec = 3; | ||||
|     #   }; | ||||
|     # }; | ||||
|   } else {}); | ||||
| } | ||||
| @@ -27,6 +27,22 @@ with lib; | ||||
|         do | ||||
|             autoload "''${file##*/}" | ||||
|         done | ||||
|         fpath+="${pkgs.python-with-my-packages}/lib/python3.11/site-packages/argcomplete/bash_completion.d" | ||||
|       ''; | ||||
|       interactiveShellInit = '' | ||||
|         eval "$(register-python-argcomplete prb)" | ||||
|         eval "$(register-python-argcomplete prod-prb)" | ||||
|         eval "$(register-python-argcomplete railbird)" | ||||
|         [ -n "$EAT_SHELL_INTEGRATION_DIR" ] && source "$EAT_SHELL_INTEGRATION_DIR/zsh" | ||||
|       ''; | ||||
|     }; | ||||
|  | ||||
|     programs.bash = { | ||||
|       interactiveShellInit = '' | ||||
|         eval "$(register-python-argcomplete prb)" | ||||
|         eval "$(register-python-argcomplete prod-prb)" | ||||
|         eval "$(register-python-argcomplete railbird)" | ||||
|         [ -n "$EAT_SHELL_INTEGRATION_DIR" ] && source "$EAT_SHELL_INTEGRATION_DIR/bash" | ||||
|       ''; | ||||
|     }; | ||||
|  | ||||
| @@ -47,6 +63,7 @@ with lib; | ||||
|       localBinInPath = true; | ||||
|       shellAliases = { | ||||
|         df_ssh = "TERM='xterm-256color ssh -o StrictHostKeyChecking=no'"; | ||||
|         fix_nix = "LD_LIBRARY_PATH='' nix"; | ||||
|       }; | ||||
|       variables = { | ||||
|         ROFI_SYSTEMD_TERM = "alacritty -e"; | ||||
|   | ||||
| @@ -1,19 +1,4 @@ | ||||
| { pkgs, ... }: | ||||
| let | ||||
|   my-python-packages = python-packages: with python-packages; [ | ||||
|     appdirs | ||||
|     ipdb | ||||
|     ipython | ||||
|     numpy | ||||
|     openpyxl | ||||
|     pip | ||||
|     requests | ||||
|     tox | ||||
|     virtualenv | ||||
|     virtualenvwrapper | ||||
|   ]; | ||||
|   python-with-my-packages = pkgs.python311.withPackages my-python-packages; | ||||
| in | ||||
| { | ||||
|   nixpkgs.config.allowBroken = true; | ||||
|  | ||||
| @@ -30,11 +15,14 @@ in | ||||
|     efibootmgr | ||||
|     emacs | ||||
|     fd | ||||
|     ffmpeg | ||||
|     bento4 | ||||
|     file | ||||
|     gawk | ||||
|     gcc | ||||
|     gdb | ||||
|     git-lfs | ||||
|     git-fame | ||||
|     git-sync | ||||
|     gitFull | ||||
|     glxinfo | ||||
| @@ -46,11 +34,13 @@ in | ||||
|     iotop | ||||
|     ispell | ||||
|     jq | ||||
|     just | ||||
|     lshw | ||||
|     lsof | ||||
|     magic-wormhole-rs | ||||
|     ncdu | ||||
|     neofetch | ||||
|     neovim | ||||
|     nix-index | ||||
|     pass | ||||
|     patchelf | ||||
|   | ||||
| @@ -1,6 +0,0 @@ | ||||
| #!/usr/bin/env sh | ||||
|  | ||||
| nix flake lock --update-input taffybar | ||||
| nix flake lock --update-input imalison-taffybar | ||||
| nix flake lock --update-input xmonad | ||||
| nix flake lock --update-input xmonad-contrib | ||||
							
								
								
									
										645
									
								
								nixos/flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										645
									
								
								nixos/flake.lock
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,6 +1,9 @@ | ||||
| { | ||||
|   inputs = { | ||||
|     nixos-hardware = { url = "github:NixOS/nixos-hardware"; }; | ||||
|     railbird-secrets = { | ||||
|       url = "git+ssh://gitea@dev.railbird.ai:1123/railbird/secrets-flake.git"; | ||||
|     }; | ||||
|     nixos-hardware = { url = "github:colonelpanic8/nixos-hardware"; }; | ||||
|  | ||||
|     nixpkgs = { | ||||
|       url = "github:NixOS/nixpkgs/nixos-unstable"; | ||||
| @@ -22,7 +25,7 @@ | ||||
|     }; | ||||
|  | ||||
|     xmonad = { | ||||
|       url = "path:../dotfiles/config/xmonad/xmonad"; | ||||
|       url = "github:xmonad/xmonad"; | ||||
|       inputs = { | ||||
|         nixpkgs.follows = "nixpkgs"; | ||||
|         flake-utils.follows = "flake-utils"; | ||||
| @@ -31,7 +34,7 @@ | ||||
|     }; | ||||
|  | ||||
|     taffybar = { | ||||
|       url = "path:../dotfiles/config/taffybar/taffybar"; | ||||
|       url = "github:taffybar/taffybar"; | ||||
|       inputs = { | ||||
|         nixpkgs.follows = "nixpkgs"; | ||||
|         flake-utils.follows = "flake-utils"; | ||||
| @@ -59,10 +62,6 @@ | ||||
|       inputs.nixpkgs.follows = "nixpkgs"; | ||||
|     }; | ||||
|  | ||||
|     nix = { | ||||
|       url = "github:IvanMalison/nix/my2.15.1"; | ||||
|     }; | ||||
|  | ||||
|     flake-utils = { | ||||
|       url = "github:numtide/flake-utils"; | ||||
|       inputs.systems.follows = "systems"; | ||||
| @@ -103,6 +102,8 @@ | ||||
|       }; | ||||
|     }; | ||||
|  | ||||
|     vscode-server.url = "github:nix-community/nixos-vscode-server"; | ||||
|  | ||||
|     nixpkgs-regression = { url = "github:NixOS/nixpkgs"; }; | ||||
|  | ||||
|     nixified-ai = { url = "github:nixified-ai/flake"; }; | ||||
| @@ -153,10 +154,17 @@ | ||||
|       specialArgs = rec { | ||||
|         inherit inputs machineNames; | ||||
|         makeEnable = (import ./make-enable.nix) nixpkgs.lib; | ||||
|         mapValueToKeys = keys: value: builtins.listToAttrs (map (name: { inherit name value; }) keys); | ||||
|         realUsers = [ "root" "imalison" "kat" "dean" "alex" "will" ]; | ||||
|         forEachUser = mapValueToKeys realUsers; | ||||
|         keys = (import ./keys.nix); | ||||
|         usersInfo = (import ./users.nix) { | ||||
|           pkgs = { zsh = "zsh"; }; | ||||
|           inherit keys inputs system; | ||||
|         }; | ||||
|         realUsers = (builtins.attrNames | ||||
|         (nixpkgs.lib.filterAttrs | ||||
|            (_: value: (builtins.elem "isNormalUser" (builtins.attrNames value)) && value.isNormalUser) usersInfo.users.users) | ||||
|         ); | ||||
|         mapAllKeysToValue = keys: value: builtins.listToAttrs (map (name: { inherit name value; }) keys); | ||||
|         forEachUser = mapAllKeysToValue realUsers; | ||||
|       } // specialArgs; | ||||
|     }); | ||||
|   in | ||||
| @@ -169,7 +177,6 @@ | ||||
|         "cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY=" | ||||
|       ]; | ||||
|       extra-substituters = [ | ||||
|         "http://1896Folsom.duckdns.org" | ||||
|         "http://192.168.1.26:5050" | ||||
|       ]; | ||||
|       extra-trusted-public-keys = [ | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| makeEnable config "modules.games" false { | ||||
|   environment.systemPackages = with pkgs; [ | ||||
|     steam | ||||
|     heroic | ||||
|     # heroic | ||||
|   ]; | ||||
|   boot.extraModulePackages = with pkgs; [ | ||||
|     xboxdrv | ||||
|   | ||||
| @@ -21,6 +21,7 @@ makeEnable config "modules.gitea-runner" false { | ||||
|       }; | ||||
|       hostPackages = with pkgs; [ | ||||
|         bash | ||||
|         direnv | ||||
|         coreutils | ||||
|         curl | ||||
|         gawk | ||||
| @@ -29,6 +30,8 @@ makeEnable config "modules.gitea-runner" false { | ||||
|         gitFull | ||||
|         gnused | ||||
|         nodejs | ||||
|         docker | ||||
|         openssh | ||||
|         wget | ||||
|       ]; | ||||
|       enable = true; | ||||
| @@ -46,4 +49,11 @@ makeEnable config "modules.gitea-runner" false { | ||||
|         XDG_CONFIG_HOME = gitea-runner-directory; | ||||
|         XDG_CACHE_HOME = "${gitea-runner-directory}/.cache"; | ||||
|       }; | ||||
|     users.groups.gitea-runner = {}; | ||||
|     users.users.gitea-runner = { | ||||
|       isSystemUser = true; | ||||
|       group = "gitea-runner"; | ||||
|       extraGroups = ["docker"]; | ||||
|       home = "/var/lib/gitea-runner"; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -4,6 +4,10 @@ makeEnable config "modules.gitea" false { | ||||
|   services.gitea = { | ||||
|     enable = true; | ||||
|     lfs.enable = true; | ||||
|     dump = { | ||||
|       enable = true; | ||||
|       interval = "23:05"; | ||||
|     }; | ||||
|     settings.server = { | ||||
|       DOMAIN = "dev.railbird.ai"; | ||||
|       SSH_PORT = 1123; | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| { config, makeEnable, ... }: | ||||
| makeEnable config "modules.gnome" false { | ||||
|   services.xserver = { | ||||
|     desktopManager.gnome3.enable = true; | ||||
|     desktopManager.gnome.enable = true; | ||||
|     displayManager.gdm.enable = true; | ||||
|   }; | ||||
| } | ||||
|   | ||||
| @@ -14,14 +14,11 @@ | ||||
|     forwardAgent = true; | ||||
|   }; | ||||
|  | ||||
|   programs.gpg.package = pkgs.gnupg_2_4_0; | ||||
|  | ||||
|   services.gpg-agent = { | ||||
|     enable = true; | ||||
|     defaultCacheTtl = 8 * 60 * 60; | ||||
|     maxCacheTtl = 8 * 60 * 60; | ||||
|     enableSshSupport = true; | ||||
|     pinentryFlavor = "qt"; | ||||
|     extraConfig = '' | ||||
|       allow-emacs-pinentry | ||||
|       allow-loopback-pinentry | ||||
|   | ||||
							
								
								
									
										14
									
								
								nixos/justfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								nixos/justfile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| switch *args: | ||||
| 	sudo nixos-rebuild switch --flake '.#' --impure {{args}} | ||||
|  | ||||
| fix-local-path-issue: | ||||
| 	nix flake lock --update-input imalison-taffybar | ||||
|  | ||||
|  | ||||
| expire-home-manager-generations: | ||||
| 	#!/usr/bin/env bash | ||||
| 	set -euxo pipefail | ||||
| 	for user in $(awk -F':' '{ if ($3 >= 1000 && $7 !~ /nologin|false|sync|shutdown|halt/) print $1 }' /etc/passwd); do | ||||
| 	    echo $user | ||||
| 	    sudo su - $user -c 'home-manager expire-generations -1days' | ||||
| 	done | ||||
| @@ -1,4 +1,5 @@ | ||||
| rec { | ||||
|   giteaSecret = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIHRNHlKPGVnOATsbnkPccyK+C15TWGKbBwqNKt0UcQ81 imalison@adele"; | ||||
|   hostKeys = [ | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIG3UqIYs/NY0okKuiIO+dU2OM7A8vv3b6//GedagvLoX ryzen-shine.local" | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAINFbM1sL/vlDhrqPV1OMIGi4dKG0tMKhWSXx95ccbfyM biskcomp.local" | ||||
| @@ -21,9 +22,11 @@ rec { | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIMCJ08qswd3OoApAIHQwojEUJ4sre89vSngbM3x5pBP2 imalison@jay-lenovo.local" # Kat's Lenovo Legion | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOVGIGnpkU7HNQ/zl/Ffi562M+laWY9/yIjB63BCMiTS kat@nixcomp.local" | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO3tlMePru6ZlSuf8yUii3N1dy3WwJnSQAt3EgETkctK kat@jay-lenovo.local" | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIFrOYD3ReFc2+xFUylBFHREcm1lO7BRJGW5JrOoY3I8s ivanm@strixi-minaj" | ||||
|   ]; | ||||
|   deanKeys = [ | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAICDvbEVL+y7eV4+mtxOuHwyomBBQ6uYMesctstua20+e deanwenstrand@deans-mbp-2.lan" | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIFeXvPyHIYBPtn6QJtOrjlBUsZjDonVRfmWqTTM2ITWx nixos@nixos" | ||||
|   ]; | ||||
|   alexKeys = [ | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIP2SQkJenAX67Ze99SKOVpKDD1XvAZnxQ8RLP0dL/Ej2 alexm@MALISONSERVER" | ||||
| @@ -42,4 +45,14 @@ rec { | ||||
|   ]; | ||||
|   agenixKeys = hostKeys ++ kanivanKeys; | ||||
|   allKeys = loewyKeys ++ mikeKeys ++ kanivanKeys ++ deanKeys ++ alexKeys ++ hostKeys; | ||||
|   railbird-sf = [ | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIDozY/3Cd9npaYPCgIn/E7MjW9c7Zb5/wTO5Qi7yRU45 root@railbird-sf" | ||||
|   ]; | ||||
|   micahKeys = [ | ||||
|     "AAAAB3NzaC1yc2EAAAADAQABAAACAQC4ayU9sly58EHQ2YdrnoJ5o0mFD8I8UiDvN3kVh6oSMMQ9wkVzLUY6wUzlc0uq3P/OYco9mURMt83C+lY4UC+jvN09nIEHV7yVJWsKV3ntmnEqM63e9cOWnpC9XA1MSha7xrf9DaO/doxST4fY6ixZA+nbE0bFgNTqyjzdya7pCamAdnPqKqwUEha+0KfpA8TJlrfgrDLd65f2/+jLU8fhTkU6yhrJ9Piq7C+RwVTu/dlrp50PNirfQRSa7vUPNS8Y973XtK6jzB/xS2Qc6iGJ+4QcCy6lgu2xksO/MNIimZYGOCP2yx6/GDp/gnOlAktrJ3flMycJdEHkZVH61HfQV76O/mY3tck/SiCwhuNxXw0uh9wf4UO8JHlnJcsIsBkSBemJsxQul+G7kV4EV/gqW/iO5U2nKmDqbwNWigO9mN44LqBOwsnAnu78kiSE8sNCEdSy/qVWloBw4VyT/emvmTwP1okh/CKNnu0/HmfSNL6Vib1XuvKSPvrUIOLMrSeRdtu85LrWaS0CvKEoMrIgpvc+3jHtdbxwINE3JBGrbXvfe20CuHl6Fx0ONkhirRmrjG7iUjV/4c6nS2aguPVsGi7q3GYvtz7cNEe3XbfpZaHzrCncnoQPbnSDLjHdeZf4O5Aew6iOwwkpgBBDA3lJO55ujq2vNbgkpH3hmQjltQ==" | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBEBce6E/XCdo8+dC4PPyyTsO/Z0BZxuz0IrTLaGehrT weitzman.micah@gmail.com" | ||||
|   ]; | ||||
|   benKeys = [ | ||||
|     "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIAJ6lD0c+frh2vzQjvsrsmJpwM1ovaY59m5NNPml5G+E benjamin.j.corner@gmail.com" | ||||
|   ]; | ||||
| } | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
| { | ||||
|   imports = [ | ||||
|     ../configuration.nix | ||||
|     inputs.nixos-hardware.nixosModules.dell-xps-17-9700-intel | ||||
|     inputs.nixos-hardware.nixosModules.dell-xps-17-9700-nvidia | ||||
|   ]; | ||||
|  | ||||
|   modules.base.enable = true; | ||||
| @@ -15,14 +15,21 @@ | ||||
|   modules.syncthing.enable = true; | ||||
|   modules.fonts.enable = true; | ||||
|   modules.nixified-ai.enable = false; | ||||
|   modules.gitea-runner.enable = true; | ||||
|   modules.gitea-runner.enable = false; | ||||
|  | ||||
|   hardware.enableRedistributableFirmware = true; | ||||
|  | ||||
|   environment.systemPackages = with pkgs; [ | ||||
|     android-studio | ||||
|   ]; | ||||
|  | ||||
|   boot.kernelPackages = pkgs.linuxPackages_latest; | ||||
|   boot.initrd.availableKernelModules = [ "xhci_pci" "nvme" "usb_storage" "sd_mod" "rtsx_pci_sdmmc" ]; | ||||
|   boot.initrd.kernelModules = [ ]; | ||||
|   boot.kernelModules = [ "kvm-intel" ]; | ||||
|   services.xserver = { | ||||
|     videoDrivers = [ "nvidia" ]; | ||||
|   }; | ||||
|   boot.loader.systemd-boot.enable = true; | ||||
|   boot.loader.efi.canTouchEfiVariables = true; | ||||
|  | ||||
|   | ||||
							
								
								
									
										39
									
								
								nixos/machines/bencbox.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								nixos/machines/bencbox.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | ||||
| { lib, pkgs, config, inputs, forEachUser, ... }: | ||||
| { | ||||
|   imports = [ | ||||
|     ../configuration.nix | ||||
|   ]; | ||||
|   services.xserver.enable = true; | ||||
|   environment.systemPackages = with pkgs; [ | ||||
|     sublime | ||||
|     vlc | ||||
|   ]; | ||||
|   modules.desktop.enable = false; | ||||
|   modules.plasma.enable = false; | ||||
|   imalison.nixOverlay.enable = false; | ||||
|   modules.wsl.enable = true; | ||||
|  | ||||
|   networking.hostName = "bencbox"; | ||||
|  | ||||
|   wsl.defaultUser = "ben"; | ||||
|   system.stateVersion = "22.05"; | ||||
|  | ||||
|   home-manager.users = forEachUser { | ||||
|     home.stateVersion = "22.05"; | ||||
|   }; | ||||
|  | ||||
|   users.users.ben = { | ||||
|     extraGroups = [ | ||||
|       "audio" | ||||
|       "adbusers" | ||||
|       "disk" | ||||
|       "docker" | ||||
|       "networkmanager" | ||||
|       "openrazer" | ||||
|       "plugdev" | ||||
|       "syncthing" | ||||
|       "systemd-journal" | ||||
|       "video" | ||||
|     ] ++ ["wheel"]; | ||||
|   }; | ||||
| } | ||||
| @@ -7,6 +7,12 @@ in | ||||
|     ../raspberry-pi.nix | ||||
|   ]; | ||||
|  | ||||
|   users.users.nginx = { | ||||
|     group = "nginx"; | ||||
|     isSystemUser = true; | ||||
|     extraGroups = ["syncthing"]; | ||||
|   }; | ||||
|  | ||||
|   modules.raspberry-pi.enable = true; | ||||
|  | ||||
|   modules.base.enable = true; | ||||
| @@ -40,6 +46,15 @@ in | ||||
|     defaults.email = "IvanMalison@gmail.com"; | ||||
|   }; | ||||
|  | ||||
|   # services.nextcloud = { | ||||
|   #   enable = true; | ||||
|   #   hostName = "nextcloud.railbird.ai"; | ||||
|   #   config = { | ||||
|   #     dbtype = "pgsql"; | ||||
|   #     database.createLocally = true; | ||||
|   #   }; | ||||
|   # }; | ||||
|  | ||||
|   services.nginx = { | ||||
|     enable = true; | ||||
|     recommendedProxySettings = true; | ||||
| @@ -53,6 +68,23 @@ in | ||||
|           proxyPass = "http://[::1]:8222"; | ||||
|         }; | ||||
|       }; | ||||
|       "cache.railbird.ai" = { | ||||
|         enableACME = true; | ||||
|         forceSSL = true; | ||||
|         locations."/" = { | ||||
|           proxyPass = "http://192.168.1.20:3090"; | ||||
|         }; | ||||
|       }; | ||||
|       "syncthing.railbird.ai" = { | ||||
|         enableACME = true; | ||||
|         forceSSL = true; | ||||
|         root = "/var/lib/syncthing/railbird"; | ||||
|         locations."/" = { | ||||
|           extraConfig = '' | ||||
|             autoindex on; | ||||
|           ''; | ||||
|         }; | ||||
|       }; | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
| @@ -66,7 +98,7 @@ in | ||||
|   }; | ||||
|  | ||||
|   services.home-assistant = { | ||||
|     enable = true; | ||||
|     enable = false; | ||||
|     extraComponents = [ | ||||
|       # Components required to complete the onboarding | ||||
|       "met" | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| { config, lib, pkgs, ... }: | ||||
| { config, lib, pkgs, forEachUser, ... }: | ||||
| 
 | ||||
| { | ||||
|   imports = [ | ||||
| @@ -7,7 +7,7 @@ | ||||
| 
 | ||||
|   modules.base.enable = true; | ||||
|   modules.desktop.enable = true; | ||||
|   modules.xmonad.enable = true; | ||||
|   modules.xmonad.enable = false; | ||||
|   modules.extra.enable = false; | ||||
|   modules.code.enable = true; | ||||
|   modules.games.enable = false; | ||||
| @@ -34,29 +34,15 @@ | ||||
|   services.xserver.libinput.enable = true; | ||||
| 
 | ||||
|   fileSystems."/" = { | ||||
|     device = "/dev/disk/by-uuid/58218a04-3ba1-4295-86bb-ada59f75e3b6"; | ||||
|     device = "/dev/disk/by-uuid/36864608-8e74-42b8-a075-27b59ef2701d"; | ||||
|     fsType = "ext4"; | ||||
|   }; | ||||
| 
 | ||||
|   boot.initrd.luks.devices."cryptroot".device = "/dev/disk/by-uuid/8142784e-45c6-4a2b-91f1-09df741ac00f"; | ||||
| 
 | ||||
|   fileSystems."/boot" = { | ||||
|     device = "/dev/disk/by-uuid/36E1-BE93"; | ||||
|     fsType = "vfat"; | ||||
|   }; | ||||
| 
 | ||||
|   systemd.services.resume-fix = { | ||||
|     description = "Fixes acpi immediate resume after suspend"; | ||||
|     wantedBy = [ "multi-user.target" "post-resume.target" ]; | ||||
|     after = [ "multi-user.target" "post-resume.target" ]; | ||||
|     script = '' | ||||
|       if ${pkgs.gnugrep}/bin/grep -q '\bXHC\b.*\benabled\b' /proc/acpi/wakeup; then | ||||
|       echo XHC > /proc/acpi/wakeup | ||||
|       fi | ||||
|     ''; | ||||
|     serviceConfig.Type = "oneshot"; | ||||
|   }; | ||||
| 
 | ||||
|   swapDevices = [ | ||||
|     { | ||||
|       device = "/swapfile"; | ||||
| @@ -65,10 +51,12 @@ | ||||
|     } | ||||
|   ]; | ||||
| 
 | ||||
|   networking.hostName = "ivanm-dfinity-razer"; | ||||
|   networking.hostName = "david-blade"; | ||||
| 
 | ||||
|   nix.settings.maxJobs = lib.mkDefault 12; | ||||
|   home-manager.users = forEachUser { | ||||
|     home.stateVersion = "24.05"; | ||||
|   }; | ||||
| 
 | ||||
|   powerManagement.cpuFreqGovernor = lib.mkDefault "powersave"; | ||||
|   system.stateVersion = "18.03"; | ||||
|   system.stateVersion = "24.05"; | ||||
| } | ||||
							
								
								
									
										21
									
								
								nixos/machines/dean-zephyrus.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								nixos/machines/dean-zephyrus.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| { lib, pkgs, config, inputs, forEachUser, ... }: | ||||
| { | ||||
|   imports = [ | ||||
|     ../configuration.nix | ||||
|   ]; | ||||
|   services.xserver.enable = true; | ||||
|   environment.systemPackages = with pkgs; [sublime]; | ||||
|   modules.desktop.enable = false; | ||||
|   modules.plasma.enable = false; | ||||
|   imalison.nixOverlay.enable = false; | ||||
|   modules.wsl.enable = true; | ||||
|  | ||||
|   networking.hostName = "dean-zephyrus"; | ||||
|  | ||||
|   wsl.defaultUser = "dean"; | ||||
|   system.stateVersion = "22.05"; | ||||
|  | ||||
|   home-manager.users = forEachUser { | ||||
|     home.stateVersion = "22.05"; | ||||
|   }; | ||||
| } | ||||
| @@ -8,6 +8,7 @@ | ||||
|   features.full.enable = true; | ||||
|  | ||||
|   environment.systemPackages = with pkgs; [ | ||||
|     android-studio | ||||
|     linuxPackages_latest.perf | ||||
|     zenmonitor | ||||
|   ]; | ||||
| @@ -25,13 +26,13 @@ | ||||
|   boot.loader.systemd-boot.enable = true; | ||||
|   boot.loader.efi.canTouchEfiVariables = true; | ||||
|  | ||||
|   modules.postgres.enable = true; | ||||
|  | ||||
|   networking.networkmanager.enable = true; | ||||
|  | ||||
|   services.xserver = { | ||||
|       enable = true; | ||||
|       libinput.enable = true; | ||||
|       displayManager.sddm.enable = true; | ||||
|       desktopManager.plasma5.enable = true; | ||||
|       videoDrivers = [ "amdgpu" ]; | ||||
|   }; | ||||
|  | ||||
|   | ||||
| @@ -15,6 +15,7 @@ | ||||
|   modules.fonts.enable = true; | ||||
|   modules.nixified-ai.enable = false; | ||||
|   modules.gitea-runner.enable = true; | ||||
|   modules.postgres.enable = true; | ||||
|  | ||||
|   hardware.enableRedistributableFirmware = true; | ||||
|  | ||||
| @@ -44,6 +45,10 @@ | ||||
|       fsType = "vfat"; | ||||
|     }; | ||||
|  | ||||
|   swapDevices = [ | ||||
|     { device = "/dev/disk/by-uuid/598e9aa1-4940-4410-a2fa-3dfd8b7d2c0d"; } | ||||
|   ]; | ||||
|  | ||||
|   home-manager.users = forEachUser { | ||||
|     home.stateVersion = "23.11"; | ||||
|   }; | ||||
|   | ||||
| @@ -5,8 +5,12 @@ | ||||
|   ]; | ||||
|  | ||||
|   features.full.enable = true; | ||||
|   modules.cache-server.enable = true; | ||||
|   modules.cache-server = { | ||||
|     enable = true; | ||||
|     port = 3090; | ||||
|   }; | ||||
|   modules.gitea-runner.enable = true; | ||||
|   modules.vscode.enable = true; | ||||
|  | ||||
|   networking.hostName = "nixquick"; | ||||
|  | ||||
|   | ||||
| @@ -57,11 +57,13 @@ | ||||
|   features.full.enable = false; | ||||
|   modules.base.enable = true; | ||||
|   modules.desktop.enable = true; | ||||
|   modules.xmonad.enable = true; | ||||
|   modules.xmonad.enable = false; | ||||
|   modules.gnome.enable = true; | ||||
|   modules.code.enable = true; | ||||
|   modules.syncthing.enable = true; | ||||
|   modules.fonts.enable = true; | ||||
|   modules.plasma.enable = false; | ||||
|   modules.gitea-runner.enable = true; | ||||
|  | ||||
|   fileSystems."/" = | ||||
|     { device = "/dev/disk/by-uuid/a317d456-6f84-41ee-a149-8e466e414aae"; | ||||
| @@ -77,13 +79,15 @@ | ||||
|     [ { device = "/dev/disk/by-uuid/129345f3-e1e1-4d45-9db9-643160c6d564"; } | ||||
|     ]; | ||||
|  | ||||
|   environment.systemPackages = with pkgs; [ | ||||
|     android-studio | ||||
|   ]; | ||||
|  | ||||
|   networking.useDHCP = lib.mkDefault true; | ||||
|   nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux"; | ||||
|   powerManagement.cpuFreqGovernor = lib.mkDefault "powersave"; | ||||
|   hardware.cpu.amd.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; | ||||
|    | ||||
|  | ||||
|   home-manager.users = forEachUser { | ||||
|      home.stateVersion = "23.11"; | ||||
|   }; | ||||
|   | ||||
| @@ -13,6 +13,7 @@ | ||||
|     port = 3090; | ||||
|   }; | ||||
|   modules.gitea-runner.enable = true; | ||||
|   modules.postgres.enable = true; | ||||
|  | ||||
|   boot.loader.systemd-boot.configurationLimit = 5; | ||||
|  | ||||
| @@ -29,29 +30,6 @@ | ||||
|  | ||||
|   services.autorandr = { | ||||
|     enable = true; | ||||
|     profiles = { | ||||
|       "1896Office" = { | ||||
|         fingerprint = { | ||||
|           DP-0 = "00ffffffffffff0010ace4a153364b300c200104b55123783bfce1b04d3bb8250e505421080001010101010101010101010101010101e77c70a0d0a029503020150829623100001a000000ff0023473749594d78677741413052000000fd0001afffff63010a202020202020000000fc0044656c6c20415733343233445702d8020320f12309070183010000654b04000101e305c000e2006ae6060501634b004ed470a0d0a046503020e50c29623100001a00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000009970127903000f000aa4140e0e07012045000002010d310cdb4dbd13b85b620e01455403013c520101046f0d9f002f801f009f0554004c000400663801046f0d9f002f801f009f0566005e0004008b8101046f0d9f002f801f009f057e007600040000000000000000000000000000000000000000000000000000000000005f90"; | ||||
|           HDMI-0 = "00ffffffffffff0010ac67d0534d39312d1a0103803c2278ee4455a9554d9d260f5054a54b00b300d100714fa9408180778001010101565e00a0a0a029503020350055502100001a000000ff00483759434336423831394d530a000000fc0044454c4c205532373135480a20000000fd0038561e711e000a202020202020019e020322f14f1005040302071601141f1213202122230907078301000065030c001000023a801871382d40582c250055502100001e011d8018711c1620582c250055502100009e011d007251d01e206e28550055502100001e8c0ad08a20e02d10103e9600555021000018483f00ca808030401a50130055502100001e00000094"; | ||||
|         }; | ||||
|         config = { | ||||
|           DP-0 = { | ||||
|             enable = true; | ||||
|             mode = "3440x1440"; | ||||
|             rate = "143.97"; | ||||
|             position = "0x1440"; | ||||
|             primary = true; | ||||
|           }; | ||||
|           HDMI-0 = { | ||||
|             enable = true; | ||||
|             rate = "59.95"; | ||||
|             mode = "2560x1440"; | ||||
|             position = "440x0"; | ||||
|           }; | ||||
|         }; | ||||
|       }; | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   hardware.enableRedistributableFirmware = true; | ||||
| @@ -96,7 +74,7 @@ | ||||
|     options = [ "nofail" ]; | ||||
|   }; | ||||
|  | ||||
|   swapDevices =[ | ||||
|   swapDevices = [ | ||||
|     { device = "/dev/disk/by-uuid/f719b44e-295a-4909-9a60-84f87acb7f77"; } | ||||
|   ]; | ||||
|  | ||||
|   | ||||
							
								
								
									
										34
									
								
								nixos/machines/strixi-minaj-wsl.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								nixos/machines/strixi-minaj-wsl.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| { lib, pkgs, config, inputs, forEachUser, ... }: | ||||
| { | ||||
|   imports = [ | ||||
|     ../configuration.nix | ||||
|   ]; | ||||
|  | ||||
|   modules.wsl.enable = true; | ||||
|  | ||||
|   networking.hostName = "strixi-minaj-wsl"; | ||||
|  | ||||
|   wsl.defaultUser = "imalison"; | ||||
|   system.stateVersion = "23.11"; # Did you read the comment? | ||||
|  | ||||
|   home-manager.users = forEachUser { | ||||
|     home.stateVersion = "23.11"; | ||||
|   }; | ||||
|  | ||||
|   programs.gnupg = { | ||||
|     agent = { | ||||
|       pinentryPackage = pkgs.pinentry-curses; | ||||
|       enable = true; | ||||
|       enableSSHSupport = true; | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   nixpkgs.config.permittedInsecurePackages = [ | ||||
|     "openssl-1.0.2u" | ||||
|     "electron-12.2.3" | ||||
|     "etcher" | ||||
|     "electron-19.1.9" | ||||
|     "openssl-1.1.1w" | ||||
|     "nix-2.16.2" | ||||
|   ]; | ||||
| } | ||||
							
								
								
									
										70
									
								
								nixos/machines/strixi-minaj.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								nixos/machines/strixi-minaj.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| { config, lib, pkgs, inputs, forEachUser, ... }: | ||||
|  | ||||
| { | ||||
|   imports = [ | ||||
|     ../configuration.nix | ||||
|   ]; | ||||
|  | ||||
|   modules.base.enable = true; | ||||
|   modules.desktop.enable = true; | ||||
|   modules.xmonad.enable = true; | ||||
|   modules.extra.enable = false; | ||||
|   modules.code.enable = true; | ||||
|   modules.games.enable = false; | ||||
|   modules.syncthing.enable = true; | ||||
|   modules.fonts.enable = true; | ||||
|   modules.nixified-ai.enable = false; | ||||
|   modules.gitea-runner.enable = false; | ||||
|  | ||||
|   hardware.enableRedistributableFirmware = true; | ||||
|  | ||||
|   environment.systemPackages = with pkgs; [ | ||||
|     android-studio | ||||
|   ]; | ||||
|  | ||||
|   services.xserver.dpi = 96; | ||||
|   boot.kernelPackages = pkgs.linuxPackages_latest; | ||||
|   boot.initrd.availableKernelModules = [ "vmd" "xhci_pci" "thunderbolt" "nvme" "usbhid" "usb_storage" "sd_mod" ]; | ||||
|   boot.initrd.kernelModules = [ ]; | ||||
|   boot.kernelModules = [ "kvm-intel" ]; | ||||
|   boot.extraModulePackages = [ ]; | ||||
|   services.xserver = { | ||||
|     videoDrivers = [ "nvidia" ]; | ||||
|   }; | ||||
|   hardware.opengl = { | ||||
|     enable = true; | ||||
|     driSupport = true; | ||||
|     driSupport32Bit = true; | ||||
|   }; | ||||
|   hardware.nvidia.package = config.boot.kernelPackages.nvidiaPackages.production; | ||||
|   hardware.nvidia.modesetting.enable = true; | ||||
|   boot.loader.systemd-boot.enable = true; | ||||
|   boot.loader.efi.canTouchEfiVariables = true; | ||||
|  | ||||
|   services.asusd.enable = true; | ||||
|  | ||||
|   fileSystems."/" = | ||||
|     { device = "/dev/disk/by-uuid/fc06a54c-cc45-423a-914b-8dfcb5939106"; | ||||
|       fsType = "ext4"; | ||||
|     }; | ||||
|  | ||||
|   fileSystems."/boot" = | ||||
|     { device = "/dev/disk/by-uuid/B28A-829A"; | ||||
|       fsType = "vfat"; | ||||
|     }; | ||||
|  | ||||
|   swapDevices = | ||||
|     [ { device = "/dev/disk/by-uuid/27f277a0-b552-43a0-904d-625e48922bb9"; } | ||||
|     ]; | ||||
|  | ||||
|   networking.hostName = "strixi-minaj"; | ||||
|  | ||||
|   powerManagement.cpuFreqGovernor = lib.mkDefault "performance"; | ||||
|   hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; | ||||
|  | ||||
|   home-manager.users = forEachUser { | ||||
|     home.stateVersion = "23.05"; | ||||
|   }; | ||||
|  | ||||
|   system.stateVersion = "23.05"; | ||||
| } | ||||
| @@ -6,7 +6,7 @@ | ||||
|  | ||||
|   options = { | ||||
|     imalison.nixOverlay.enable = lib.mkOption { | ||||
|       default = true; | ||||
|       default = false; | ||||
|       type = lib.types.bool; | ||||
|     }; | ||||
|   }; | ||||
| @@ -27,12 +27,20 @@ | ||||
|       settings = { | ||||
|         keep-outputs = true; | ||||
|         keep-derivations = true; | ||||
|         substituters = [ | ||||
|           "https://cache.nixos.org" | ||||
|           "https://cuda-maintainers.cachix.org" | ||||
|         ]; | ||||
|         trusted-public-keys = [ | ||||
|           "cache.railbird.ai:KhnvcouxtIU2zxUcjJsm4bUK3o1S3p8xMf9qfZGF7/A=" | ||||
|           "cuda-maintainers.cachix.org-1:0dq3bujKpuEPMCX6U4WylrUDZ9JyUG0VpVZa7CNfq5E=" | ||||
|         ]; | ||||
|         nix-path = nixPath; | ||||
|       }; | ||||
|       channel.enable = false; | ||||
|       nixPath = [ | ||||
|         "nixpkgs=${inputs.nixpkgs.outPath}" | ||||
|       ]; | ||||
|       settings.nix-path = nixPath; | ||||
|     }; | ||||
|  | ||||
|     nixpkgs.overlays = [ | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| final: prev: { | ||||
|   rofi-systemd = prev.rofi-systemd.overrideAttrs(_: { | ||||
|   rofi-systemd = prev.rofi-systemd.overrideAttrs (_: { | ||||
|     src = prev.fetchFromGitHub { | ||||
|       repo = "rofi-systemd"; | ||||
|       owner = "IvanMalison"; | ||||
| @@ -8,7 +8,7 @@ final: prev: { | ||||
|     }; | ||||
|   }); | ||||
|  | ||||
|   git-sync = prev.git-sync.overrideAttrs(_: { | ||||
|   git-sync = prev.git-sync.overrideAttrs (_: { | ||||
|     src = prev.fetchFromGitHub { | ||||
|       repo = "git-sync"; | ||||
|       owner = "IvanMalison"; | ||||
| @@ -17,23 +17,24 @@ final: prev: { | ||||
|     }; | ||||
|   }); | ||||
|  | ||||
|   picom = prev.picom.overrideAttrs(_: { | ||||
|   picom = prev.picom.overrideAttrs (old: { | ||||
|     src = prev.fetchFromGitHub { | ||||
|       repo = "picom"; | ||||
|       owner = "dccsillag"; | ||||
|       rev = "51b21355696add83f39ccdb8dd82ff5009ba0ae5"; | ||||
|       sha256 = "sha256-crCwRJd859DCIC0pEerpDqdX2j8ZrNAzVaSSB3mTPN8=="; | ||||
|     }; | ||||
|     nativeBuildInputs = old.nativeBuildInputs ++ [final.pcre]; | ||||
|   }); | ||||
|  | ||||
|   expressvpn = prev.expressvpn.overrideAttrs(_: { | ||||
|   expressvpn = prev.expressvpn.overrideAttrs (_: { | ||||
|     src = prev.fetchurl { | ||||
|       url = "https://www.expressvpn.works/clients/linux/expressvpn_3.46.0.7-1_amd64.deb"; | ||||
|       hash = "sha256-v0rr1s32jj79A8IGfJgSGJVlz7rSnZYn4ealOpqee0w="; | ||||
|     }; | ||||
|   }); | ||||
|  | ||||
|   gnupg_2_4_0 = prev.gnupg.overrideAttrs(_: rec { | ||||
|   gnupg_2_4_0 = prev.gnupg.overrideAttrs (_: rec { | ||||
|     pname = "gnupg"; | ||||
|     # 2.4.1 breaks emacs | ||||
|     version = "2.4.0"; | ||||
| @@ -48,6 +49,24 @@ final: prev: { | ||||
|     withTreeSitter = true; | ||||
|   }; | ||||
|  | ||||
|   python-with-my-packages = let | ||||
|     my-python-packages = python-packages: | ||||
|       with python-packages; [ | ||||
|         argcomplete | ||||
|         appdirs | ||||
|         ipdb | ||||
|         ipython | ||||
|         numpy | ||||
|         openpyxl | ||||
|         pip | ||||
|         requests | ||||
|         tox | ||||
|         virtualenv | ||||
|         virtualenvwrapper | ||||
|       ]; | ||||
|   in | ||||
|     final.python311.withPackages my-python-packages; | ||||
|  | ||||
|   # gitea = prev.gitea.overrideAttrs(_: { | ||||
|   #   src = prev.fetchFromGitHub { | ||||
|   #     repo = "gitea"; | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| { config, makeEnable, ... }: | ||||
| makeEnable config "modules.plasma" true { | ||||
|   services.displayManager.sddm.enable = true; | ||||
|   services.xserver = { | ||||
|     desktopManager.plasma5.enable = true; | ||||
|     displayManager.sddm.enable = true; | ||||
|   }; | ||||
| } | ||||
|   | ||||
							
								
								
									
										32
									
								
								nixos/postgres.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								nixos/postgres.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| { pkgs, config, makeEnable, realUsers, ... }: | ||||
| makeEnable config "modules.postgres" true { | ||||
|   services.postgresql = { | ||||
|     enable = true; | ||||
|     package = pkgs.postgresql_15; | ||||
|     ensureDatabases = [ "railbird" "public" ]; | ||||
|     authentication = pkgs.lib.mkOverride 10 '' | ||||
|       #type database  DBuser  CIDR-ADDRESS auth-method | ||||
|       local all       all                  trust | ||||
|       host  all       all     0.0.0.0/0    trust | ||||
|       host  all       all     ::1/128      trust | ||||
|     ''; | ||||
|     ensureUsers = map (username: { | ||||
|         name = username; | ||||
|         ensureClauses = { | ||||
|           superuser = true; | ||||
|           createrole = true; | ||||
|           createdb = true; | ||||
|         }; | ||||
|     }) realUsers; | ||||
|     # initialScript = pkgs.writeText "init-sql-script" '' | ||||
|     #   CREATE DATABASE IF NOT EXISTS railbird; | ||||
|     #   \c railbird | ||||
|     #   CREATE SCHEMA IF NOT EXISTS railbird; | ||||
|     # ''; | ||||
|   }; | ||||
|   services.pgadmin = { | ||||
|     enable = false; | ||||
|     initialEmail = "IvanMalison@gmail.com"; | ||||
|     initialPasswordFile = (builtins.toFile "password" "This is the content of the file."); | ||||
|   }; | ||||
| } | ||||
							
								
								
									
										6
									
								
								nixos/rabbitmq.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								nixos/rabbitmq.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| { pkgs, config, makeEnable, realUsers, ... }: | ||||
| makeEnable config "modules.rabbitmq" true { | ||||
|   services.rabbitmq = { | ||||
|     enable = true; | ||||
|   }; | ||||
| } | ||||
 Submodule nixos/railbird.ai deleted from 74ee66bcb6
									
								
							| @@ -1,4 +0,0 @@ | ||||
| #!/usr/bin/env sh | ||||
| rm flake.lock | ||||
| nix flake update --impure --inputs-from . | ||||
| sudo nixos-rebuild switch --flake '.#' --impure | ||||
| @@ -1,48 +1,48 @@ | ||||
| age-encryption.org/v1 | ||||
| -> ssh-ed25519 ZgrTqA K4oHCwQSxZ1cppAdEPDgn+3dU+LSgDIfAU0by61sLSc | ||||
| fZe+0S7OMpGCEjvc1nRIYCbnorob+VVmsKuqfF8W8b0 | ||||
| -> ssh-ed25519 ZaBdSg J8j0FbAPl4Qpib86klH5zTUgsw3cN8mVIYzl3NwcKQs | ||||
| i5o2r1MuIgS7Nn8kEqndDrBzQYbQHNskJrfQ4YdL6kU | ||||
| -> ssh-ed25519 MHZylw jaWeU0jQ/B21yGKexPCXFvD3iX7s/sx2/ipyd3eRgUA | ||||
| 6DIihnfwP7CxHe4MuNhCtJwHYxS+kJHvvQ1dPsUC8Os | ||||
| -> ssh-ed25519 sIUg6g ntffSUnIvDQ0LjnEhqmuvChB8Sh0r+b/uHnOLCe+XGU | ||||
| PcqirbvgQfbwXuglHeLLcWIBW9Y1h10MTWDVKvGC7WM | ||||
| -> ssh-ed25519 TnanwQ xwUFbOhYArMRVs6/LTwRSTeTL4hcTmm0Lc0umSKWYjs | ||||
| te8laPg+SWEYlzMKi7k8SWbxOvRBldfq1/yLK1zsHXU | ||||
| -> ssh-ed25519 ZgrTqA O0XHnLd6cH/2OZyZWRvB028wmx8x8b4ojoqzidpANQM | ||||
| tQXIb/FsHcXwBet9icQrU1gYxpWUXOMFnxhHq+pJegc | ||||
| -> ssh-ed25519 ZaBdSg dXtxOGI6j+NyJadTzlhTkb+6/rf5BEtUeZCnH4SjpA4 | ||||
| UCqDgtXh3tMFGz0xDyWn5I81S91CRrEJ9j4LAUN14vI | ||||
| -> ssh-ed25519 MHZylw GGmyYlC28NKCP+uuAQBO3EIqB+XY63SCkDN4e/WdGkY | ||||
| GVzmq2tmIJvFnmMnvO12Ok8gOofTRBt20HH586tNzps | ||||
| -> ssh-ed25519 sIUg6g +VSuYouQxNM8Ch9xTIdokrtAK6RU5NoMNN6nUAr+rQQ | ||||
| GDRltKHjD6D4d9Z0vq04M6ELi53GdZZFAZde/V6YzuE | ||||
| -> ssh-ed25519 TnanwQ HeLm9uq5waI09epfKCsRLFO0Ll/V9Rg6y7LAOjGKLmc | ||||
| jjpTs70FeSaxBH3OyvEfGl71kpVRZmtaCkS29VXehVw | ||||
| -> ssh-rsa gwJx0Q | ||||
| HyRLUjc/IFJ3E89A53Nkg4feaGYqAMJxxchQiOvossaBXa8q+ijm3rHIu7B1cFwj | ||||
| bHIjhjB0OHyTjG2e5opqpSf4Y5ZN46m+Yun2R+Bx9lWSpajqG0G48vZUyNVYczSH | ||||
| 7BmR1I7wMIr+twGRtzgkQT6bRJBIyNlzR85uIFxD6hXabKWMgOBJW7bS3jTnST5+ | ||||
| elgjI9FKrZKXlfG3CockvmQzfSXa2f/RBoz1cYIDYKH1E1g5K4l1nXaX3UEIeLbf | ||||
| mXCbevqQHkfSfL+MZOuBYp15qH+YCURNPe1moIQLPTeogKrL1wGdLQKZD1bnvWru | ||||
| eeRNXTWdtflRPzDgEYzquw | ||||
| -> ssh-ed25519 YFIoHA D/qb8BMMQLet27WghcZ3R42cJtclMmIvt9HK51xbmAo | ||||
| q5jPIGu5Xb/Qhq4aOvRkXMt3YqL13mpcbvQAZaEi+90 | ||||
| -> ssh-ed25519 KQfiow W+8Ns+1XRLisGKJK/ZsBbHilt4MfdSNCCWEaf7WU3FQ | ||||
| D4AHzgg8VKVYXFTxFMSVd2I9EjvpX33aTuNx+POPiSs | ||||
| -> ssh-ed25519 kScIxg UrC0SCpqBLgzgzKHo5vyiznyw0XuLGvlaIaQ9pzSD0E | ||||
| OOqxCww9ONPoSnc3jCioFymblURnt6LRGn7GRiv5MPg | ||||
| -> ssh-ed25519 HzX1zw l4+x9GZQEuMZ44l7faHKM2/qVxvlxMfeZZPn1zxVCmE | ||||
| VKNhloRSvOeTPoMNdHjdrwdrSuspmADtJXkiHHh8f0A | ||||
| -> ssh-ed25519 KQfiow ehBlMZZKtoAQoHlrpXWKdZqlZlRxb0ChQlVI6+lRUnI | ||||
| fcRaIUF7hrLd5tiOApNpVRbneXw+o16PhNN84UIthqY | ||||
| -> ssh-ed25519 1o2X0w TZ9Oacj2RjbH8xA1Jm2ZeTadzP6EEWxhRKQA1qXqLx4 | ||||
| mjfBINzktzGylI6jQVxnjkMBx+FObSX+DUn+V3MGvXQ | ||||
| -> ssh-ed25519 KQ5iUA DM05V4Av4tZmEuA2YHi+MsecDNAM8SJe7S4GTLJgFzE | ||||
| cmzJWiUNfYRnjaHN15V82NwZVK0aP1U+6D2LwCm6fCI | ||||
| -> ssh-ed25519 AKGkDw bYtN1r09N5Dp2/I4FqM8axT7eOelcuZOkeBjnLmCEhw | ||||
| aoWTidCHSj44RSa9KsKfcSAc7AbRQApJBLBQbiROACU | ||||
| -> ssh-ed25519 0eS5+A jQ5PSkWblPM6lGu4h25EDDHYLa7sGs+lEKXPqJa5HA4 | ||||
| smh/u69PfMx2EqylwqrUi6CAgLUJeoM+M8W10nTGx2M | ||||
| -> ssh-ed25519 9/4Prw GkiZaxXpmoZWr7z1oZti8Duu3otcan+41Y588lj5igY | ||||
| K9CXZhfK6OvNyGmXsLwNFXbME8JWkSAkHHika2d/CIo | ||||
| -> ssh-ed25519 gAk3+Q NkURRxA3xrGDVVrrpZ/DRcUmQSekNratAm7oNFsfETE | ||||
| cxxRshJK5Z07z6+zR/A/YpjJL5iVYU5MJFqn2Ayb57A | ||||
| -> ssh-ed25519 X6eGtQ dGRh0CZ85+eMWTl5Jw9xKV+hudCd/68cKIUv2yBFHk4 | ||||
| pGaVck8ofB1zfa40HPVmg6Ie5IBGtcHcrBjYzgyMdME | ||||
| -> ssh-ed25519 0ma8Cw vStc4U0W3tFYLt7UM7c14cDPKBMZ8V8P/7pLNWwGGQ4 | ||||
| KUnDkVWvPcZOah0J2fvRuUpPdqO7Y3S+RO45T5AOcn8 | ||||
| -> o9|-grease =+0PJ {o J4(=&# U%mg | ||||
| Ee6Nr/v2nVUTnuAZQbpDQow1p3415iGgPpUvPM8FKAc | ||||
| --- HPRO4P0TAjUX7A3WH8f/WMTRrrkAHOrazZlz276pDdo | ||||
| <EFBFBD><EFBFBD>ʿ<EFBFBD>/<2F>2<EFBFBD>ȓ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>'6aIAcʻ<63>;<EFBFBD><EFBFBD><EFBFBD><EFBFBD>x<EFBFBD>+<2B>E<><45><EFBFBD>*nJ1<0C>u<04><><EFBFBD>A<EFBFBD>и<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>)<29><>6<EFBFBD>g@<40><>_xO<78>T<10>Ǧ<EFBFBD>ѭ<EFBFBD><D1AD>.+<02>y<EFBFBD><79><EFBFBD><EFBFBD><EFBFBD><1B><>ua<04>z<EFBFBD><7A>p<EFBFBD><70>Ҝ<03>ع~<7E>z<EFBFBD>H<EFBFBD><48><EFBFBD><EFBFBD><EFBFBD><12><><EFBFBD><EFBFBD>W|}<7D><><EFBFBD><EFBFBD>U;<3B>)M | ||||
| a6q+jlWud5INiCOwPH570EdyrEOahksIsz5ehCwi21xUpsw8uDAJvwJZ4LTUk7Pp | ||||
| rgCu56ndd0LBqNAsqCO0NeP6rHj11Y9gVI1VAe8JZwQAd9uxP1wCFSamGPBAG3qU | ||||
| 6K7tSWxUJg5E5N8xn0UVasdC49PSadEBpvWOw7gxUcZSZk+zdXZkmNNJOJjblp48 | ||||
| BzjLiFs/NEapIrpx80nXurSiyN5IV97vK3owXqqYSKOoBR2JWbVeYVO47cR9UN8G | ||||
| df43ozz2wrG3tfVgy23JfRUPinDxPkUJ0AbkpD7aBuEJfFmQSDjyl+wGevf5GAOI | ||||
| rTNpOz31YvchkiynnXLhyg | ||||
| -> ssh-ed25519 YFIoHA 9Sx54ArYGvWtaM64vIuh/xNfC00Kn/6OiIL7zkK/IBI | ||||
| cHLc5wccimYC6ICqnz3e1hs+4XAHzRd32dj0/g+4q6s | ||||
| -> ssh-ed25519 KQfiow p7igfY7SkJe2k9EZMy+VEr+uYnEZZSosmAJKOWwopDU | ||||
| z3HZmOrrhK6Ns5z5EOtlgoo6IROMuo2elRrnX/I9YvI | ||||
| -> ssh-ed25519 kScIxg de1921H/EqUtCsmjytrGa/9vx41qKO/jiTTNRXRK/xg | ||||
| IzjtdSwv/FwgGyl6qumTvDi5imcUKolt5upP0hNDd1g | ||||
| -> ssh-ed25519 HzX1zw u7OB64Wzd4siphc3kyRbPwYswc/vn0eqtUiId5byuVE | ||||
| t8CF85/o71ra6IAgXAfcoCZHs4VN/ejOQVsdUZaaLqo | ||||
| -> ssh-ed25519 KQfiow uzyI3JXAF3twmqSKDZAgNEMv/Su832geK/y46hKiJCg | ||||
| qpbPTkQYUcPSuFEXoOnYmGLcAL2TH2XpkBOqeVvUVVk | ||||
| -> ssh-ed25519 1o2X0w u9pY09CQumynSF+9z59nuEuZFPwdVld8XQOLG0N4llw | ||||
| i1HrE7Nk5O/h9eYGeq+nx5UCIgO2c0ROHcwUDiFFxoM | ||||
| -> ssh-ed25519 KQ5iUA zpOP9fMu7Mqm0LbkA78KInXworz+LGpovjk5mIOOfVM | ||||
| Q2y9sMSgwIahs+7ceXY6bYha87uXcD28irc4zRYbOSE | ||||
| -> ssh-ed25519 AKGkDw mLi5T/ia2gQ9z357LYQUbgUQ37DLPhbRlR3LkPvOPk8 | ||||
| rPUwUtTwDAbn49GgLO9vfW/P8hfrhf4znvrmHiiPXLE | ||||
| -> ssh-ed25519 0eS5+A DomPBIFcr3Wxi1sfGzEBKTpRruHijRX5CDh7xk/mQgg | ||||
| u9hQHSq3w/NBv3zpIpbX3bMk2vYaNn8dl079zz4cRmE | ||||
| -> ssh-ed25519 9/4Prw kczIhptmCQmYolhBX+omXqbtTuqqEeL8Mnx2k/1c3Wg | ||||
| 3QBDp0WfYP8Ni3zZ3xk8yC5WscRa+niwjO+6Q2MR9Is | ||||
| -> ssh-ed25519 gAk3+Q HhCggnhkMhbZG1VyyjtibA7eAnnhS+ZVDMuKmFW+fiQ | ||||
| 7URzpfoMkgD/Jn0N2FV5WJxLpDOPkmI3W7yA5G+MyQg | ||||
| -> ssh-ed25519 X6eGtQ KBzu6+tTigAYC+ifRi5rGyocU0l1PfBj2KuK9yasUiw | ||||
| ShtvUv9tuuvYf7dHDnBIQtLWVkN9gaP6ryyeCVoNVIU | ||||
| -> ssh-ed25519 0ma8Cw 4kkPaMRoYuYflcHDAzBAaWd9+Q3CXV97Hs7d8sFIU3w | ||||
| 7JQH4QYVnnxhjfr0wQTqLieGc3G5ymEBdivqO2/vEWM | ||||
| -> ssh-ed25519 Tp0Z1Q 3GL4a2CUqmbEK0POxjUADiUtnA96enIKavGEJBr4QTM | ||||
| RP5mZ7PKqB29cU5ir3wiX7CDM6KuqBysO2g9HyONlKE | ||||
| --- hLdA7jp69UiOM2LP3bMxOCNnHUWwcgL2BbSsz3+D8lM | ||||
| 2<EFBFBD><EFBFBD><EFBFBD>1<EFBFBD>Q><12><EFBFBD><EFBFBD><EFBFBD><EFBFBD>2-<2D><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>R<EFBFBD>><3E><12>B<EFBFBD><42><EFBFBD>(<28>^~<7E>(<28>ۻ<EFBFBD><EFBFBD><EFBFBD>?<EFBFBD><EFBFBD>n*T<><54>MK;oN<6F>W<EFBFBD><57><EFBFBD><EFBFBD>z<EFBFBD><7A><EFBFBD>;K븬=.<2E><><EFBFBD>Ȑ<EFBFBD>J<EFBFBD>U+<2B>a<19><>Q<EFBFBD>Zr<><72>g^<5E><EFBFBD>"R<>0<14><18>J<EFBFBD><4A>c<EFBFBD><63>4d?<3F>Ȧ3<C8A6>,<2C>O<EFBFBD><4F><EFBFBD> | ||||
| @@ -1 +1 @@ | ||||
| 1896Folsom.duckdns.org:U2FTjvP95qwAJo0oGpvmUChJCgi5zQoG1YisoI08Qoo= | ||||
| cache.railbird.ai:KhnvcouxtIU2zxUcjJsm4bUK3o1S3p8xMf9qfZGF7/A= | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -1,48 +1,49 @@ | ||||
| age-encryption.org/v1 | ||||
| -> ssh-ed25519 ZgrTqA ZhQai78QiRxex0hvG+zf+qL1hbTb4/JVJVWmDG8rAUU | ||||
| yKincV6tR86Qr28JC+0+LdXWLamys7D3Zka6JKFk1sk | ||||
| -> ssh-ed25519 ZaBdSg /bWisLCN6LpAZpgwqZvtp0Bpmr4EBDZKKw67w6DwCDQ | ||||
| qdlTc0+bgu040JrSFHxVYhOOjBgL/mlpv41d7BnbBdw | ||||
| -> ssh-ed25519 MHZylw 7mUaZTrTTusBBB3c9bwD8xiYOEu2Yy0vD0/JBhIfThQ | ||||
| x9vauqbTA+OL4yObO5EHsXhSurtYTYkSH8VQKl+B4Tk | ||||
| -> ssh-ed25519 sIUg6g wPIoib/eshBQvzAKdWqD6eWyWozxKuOf9h6ebG3KmUo | ||||
| 9D74H5EqsPlrNCgrDJo7ZofwNz0JvB0GzvwI4RAILRw | ||||
| -> ssh-ed25519 TnanwQ aFqE3LuU6rjBTISLPzdz0dCcurg/8T6CLFI8ota2m2M | ||||
| sFCyTPiqu6t/qqXSdmjnDVYjIGDLEGxUPYxerUTZlFU | ||||
| -> ssh-ed25519 ZgrTqA zsIOhgeJ7P+Ahrrh+coSbVgxw6RtPymZs5ll8X2BpTA | ||||
| ON9VLFUzhFU/sxslo4Wt7EgohGdY+k58ri+G5naolLs | ||||
| -> ssh-ed25519 ZaBdSg /OzROBe2BME+hsdWTna+UV4tIEJK9lDDaZQnpUYWfmA | ||||
| PjU8bzoct2GPytjXMxbYdPlGi9RgfaGNdlcdx8X9mcs | ||||
| -> ssh-ed25519 MHZylw RKGcQyfmai8OeNo0c6zyW0KaZ4Mgt66qikomlON272c | ||||
| lO2AvsQ/3oWl0aNzitwjnFOV20H//wiuMY1MY/3WDrM | ||||
| -> ssh-ed25519 sIUg6g 8at+Rg94MgOePuOA9fUCPuxyleQHDaGPnsaNQNy6824 | ||||
| CCNrSkINVlqAhi2rzAEjnzX+aJBj8S7D5OjOc7+282I | ||||
| -> ssh-ed25519 TnanwQ JQ5HncLZsUKpXbUhRBvS+UdMa8ARJBRIK75w2kuD0Hs | ||||
| 6giGtalrSpcO2Xb7IxCvqhi7Op/wdNnhPqGOVxumutc | ||||
| -> ssh-rsa gwJx0Q | ||||
| yKgI9wnuT5YhySbf2mxkNwnSgdHv5fnaDI759day+jw7rwtV/Q/RoWPghCEfS3T9 | ||||
| +u/dFpNubL1+Sue/d0PxpJwaGV+nZb13/a1DpYZaaXYXIYiMpBaZR/3bCF1uSuOp | ||||
| LAJAqS2WlG8+ysTj5EN+RBud4sFYYZ5gp+xk+wX/aY+NIxjQ/cKhZtlk9e9THAHJ | ||||
| WYdYkc25sp7DCsj5HlIczkmx2Wn2wajJvOKOBK95Jijn/y7+Zj+hTF2MKjfRJnGw | ||||
| EoizLrr1EN2hkCbUJCwbef2NNBlUnI4A/LvKvr/2xmdw8aJc+lgEA1EssVab0Ugx | ||||
| jgBHsW+70T/yT8CbSo+n6Q | ||||
| -> ssh-ed25519 YFIoHA j1o7t3EaY5JBJFlxv406aS+5nrQbjj2xu2l/rkwsfhU | ||||
| CTlM2FFqysa2cu+tonQ+XtdkOe8lSx7bA0XX5cRuHh4 | ||||
| -> ssh-ed25519 KQfiow iTAhqJszH3qfZLcJEPsPUOfsg2lnWE1yGcFHmVqcK04 | ||||
| rAcVdfcrYcqDTUiyB1Xj3OsxQZGaXsd7XPT2ZENZxg4 | ||||
| -> ssh-ed25519 kScIxg SdRrX6jPDbApqYb0BUvoPENfO0EREAcVzov0mYiqfW0 | ||||
| YxCq3/YI0RAI6tSe2S9eFFHRiRT+cgiqKG38R1Ed0rk | ||||
| -> ssh-ed25519 HzX1zw +77mjckApgLbOn6r+E9ftgUOFFhDX7t6wQcCn8shA1c | ||||
| LzP5oBw0YDfET9c6AiuRUrDPAblExBtPfO/aLM5bTPY | ||||
| -> ssh-ed25519 KQfiow /kv2czudYV5/knn4gm9UjWkTgK7h52OSwnBtQkJ4Ogs | ||||
| x3U//RiRVbD2q+2BB7fRZ+D/mOuq2RBBrUwRaGaZ4t4 | ||||
| -> ssh-ed25519 1o2X0w sWQrEHabTxKgPXctvjbozGia0TOFNY/nMkJkbg9wjDk | ||||
| xKMdH3+dGd0I/GCuII/29D49X0pGTkB3lig3PizcfAA | ||||
| -> ssh-ed25519 KQ5iUA 0GxPwSfFhyFmgFjg17ZdQ+Np8ozLcZw4qnmJXf8e5Fs | ||||
| BmMvDNnEFqRHN/DQxTS2xYr64rsNwwcJ/ISx+tSgwIk | ||||
| -> ssh-ed25519 AKGkDw LP67Vi5XAYaeCRzKRvUol+9sYhj5DfRM2XFcfpBObCk | ||||
| sQR+s300FSVp7MGvc0lAlsiriF1yYG+gv2O8qXLC0qI | ||||
| -> ssh-ed25519 0eS5+A 6W01v2D+eo7ykmdt/c6+OngbOgPYhp3IRzOP7YycGAE | ||||
| xSiwX/pPa6u+wMP99930ZALt3fUI52k56o9DIj5MJP8 | ||||
| -> ssh-ed25519 9/4Prw OhlAdZNG5GI60FecavQWNBHWOK5u+ONItDSnJ7kW6hE | ||||
| KBybj+3HZ4FCHht8lwBqJszCMZvylSoLrnOeKslDvi0 | ||||
| -> ssh-ed25519 gAk3+Q t5ItGM7NarFQYDU4Ae+39ZIdhmnX7liY+bqRtsqY8F8 | ||||
| o+MKA8rMnXOUECFLf0bnqo4uohTjI2PN2ejvKSDbOeE | ||||
| -> ssh-ed25519 X6eGtQ JbV/sf9/HVBpVcCym7rDvSXUNvE7t1/eHQpIjksw0Cs | ||||
| UO0cDqFmcEQt+vasnMAc4O4bmEkLdkYzj9YzsMmsfzM | ||||
| -> ssh-ed25519 0ma8Cw WMNiHynQWBF/8ig0JF5tZcGruRDHHxlJOQtJalv7+lg | ||||
| 8U5QXXo3qV9QlRZobD2K4O01uQfzCd+BSViZf9fIRYo | ||||
| -> }-grease WA! | ||||
| O5uhSTAdlz9vuYJoelzj2CABhv00grAx | ||||
| --- m3xCzyC0aFdfuklw+MDS1kx0oor72n4iP9w3iaYDpJs | ||||
| <EFBFBD>1<EFBFBD><EFBFBD><EFBFBD>;b<>2_<><5F>Dz<44>	a<><61>L15Otѓ<74><D193><EFBFBD>!+<13><><1B><>Pl<50>E<EFBFBD>23<14>"kzdFIE<49><45><EFBFBD><14><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>w<EFBFBD><77>(<28><12>,<2C><>K<EFBFBD><17> | ||||
| q9YKescXHdvkSEEL+buHyFpedrkyP8KN+U5mwe4ML9bdFGsEESBjtwRs+wTHBKfR | ||||
| DGueZFt8yloafYJJi2bDSOwQM+YQ7l3I9pmkdK8xppUpoxc5lsd3za4tZvl7Q3mQ | ||||
| JMgqfQ1pwpPG8YnKEnS1rZ6DFq3wJ4dH5dOkEcSkUflUse2GrVpkFHA6B0iF4Fth | ||||
| F8cpVOpBh8zruRp5b1hNlzuC+4E4fgLC/dqo/WK17gEQmPBoVLmZurAsLUz63VBR | ||||
| XJ0cphb39Jx+OqID0pfoRx8F7pWNMXeziQ/figtfX1BVsvAgAfG/G52UQIHPBB9l | ||||
| lRbUKp533f8J4B3uQlplAQ | ||||
| -> ssh-ed25519 YFIoHA As3dFA/KZEv4uK3cABiksYAbbRKD/SAYHn6DMu5A/ho | ||||
| 1Gui6pI2/Y/4fhL+sV+ReE/Q8YzOXpa+el9ieDI63hg | ||||
| -> ssh-ed25519 KQfiow JfOvjZPAjSMEtyMj1ES5hgZQ3ChceOAgCUlAwdUWvHE | ||||
| cHOS/ogIjIt3/cpcsip/OUbTa/XTsqabxpih0Q4d+vs | ||||
| -> ssh-ed25519 kScIxg Ss92xRhzfFLuQ7cZ9qOXWYlxPosZJiIA5WUtnBn5uAA | ||||
| eFbchoQ2WFT5QZlbMp3ie2IO+oN1gDx5LEHYgtmibyU | ||||
| -> ssh-ed25519 HzX1zw CXFvvKTr+chLDjxeHIQq6YgfsyNguoqQgWMVCriq03s | ||||
| AfZclyaLfIyVgRsSt6gFw/n3Gmjz9+qqcbS+jKLUTdU | ||||
| -> ssh-ed25519 KQfiow hoWtmj8tL3hYQaCusTzoEe2wy/hzOBQF/+ygYN0j0QU | ||||
| lvfAsrOv1vtQeYvlacFyg6rlEUeb2nwxelSCkHZL1JQ | ||||
| -> ssh-ed25519 1o2X0w hSNKyIkQ5HrqUodLzWRrx+7RkxFg9A1TVuXbq+EFlw0 | ||||
| CXUpZnKGuXV34Tt4YWGL1hheYHSYB2JonuxmZC9BNZg | ||||
| -> ssh-ed25519 KQ5iUA jbUaWkNa1xj8gKEalGx7wJWcVwwDWQ5Mzq7kw0Rk3BU | ||||
| y71HcF0ApASye3RgUHEThP1aFZZX5jocKHL25qZ2yZ8 | ||||
| -> ssh-ed25519 AKGkDw n5MO4SkU61QWZ57aG+383Q3raFRdomDMXGaDMgpQUSs | ||||
| 4g2UfsdaNa++TRXNrUfVV8pj6irb0W+F10XfVAPJk+Y | ||||
| -> ssh-ed25519 0eS5+A DMk4jzjnfPWzk3kz1gwebXqJ5a3yAvqTi1fXCEBLi2k | ||||
| JL5wGUcHNQDz4Czo6yQ2Eo5sc0/psjo0O0C9unL3V0g | ||||
| -> ssh-ed25519 9/4Prw 9RMdxeyRXz8pKxAaiOrd/D5UdImOB48C0OE4x1MbSnw | ||||
| 5m4g4ZSMLP99bYR0+twroVvnowpGBPolw/u0T/wDCmk | ||||
| -> ssh-ed25519 gAk3+Q Mos0Csznmt3wZF0fE+BKlqTMJgLKR/+Yih7DTNaLF3s | ||||
| EfaOXBbeS2q36lUfydPL35GcL0qzxEyG1/g1HUk+Bjc | ||||
| -> ssh-ed25519 X6eGtQ 3uAhhDAEQQCu7MQmNbEAs8/bDxEeh50VefU+prQN5SU | ||||
| jdp6QFF9Yw3zHrbmijJQV0CqlcoOm0BU3fkJTJAsxpY | ||||
| -> ssh-ed25519 0ma8Cw +7QmGjIuxHsqeDxeLkiSvpaC7ztv+Ix0rEwEhbTeHG0 | ||||
| DUHK8xqoxnE78AMIh9z846eWcSToc6PruVERTOCdya8 | ||||
| -> ssh-ed25519 Tp0Z1Q Alv9QyL6AzdLRTyN8pn413eeKW32ql3i/WVhasuKETI | ||||
| EkkG/JknXDT5opzLSZ3Gbf8d3+FlHwwxzbZK/nCQ6ng | ||||
| --- zN1cSiDL5ZI84c9DI4ewQLqaGZJS1IR6EoSlpQC44zI | ||||
| <EFBFBD>ط<EFBFBD>ۨ9<EFBFBD>H<01>G<>.Dh{<7B>:<3A><>p<EFBFBD>2<>yY<79><59><EFBFBD>`<60>o<EFBFBD>c<EFBFBD><63>$ŵ<><0E>Z | ||||
| <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>T<EFBFBD><EFBFBD><EFBFBD>I<EFBFBD>l2<EFBFBD><EFBFBD>O<EFBFBD><14>P<EFBFBD><50><EFBFBD><EFBFBD><EFBFBD>$<24>G | ||||
| @@ -1,48 +1,48 @@ | ||||
| age-encryption.org/v1 | ||||
| -> ssh-ed25519 ZgrTqA swipq6Fr927DGa/aS5gVWl3TaGIwwyVn/pLb61AOjBc | ||||
| WZjYqhvV4UuYRWE1VOhlrZZwDZl5LaTgwJRpidx6xBE | ||||
| -> ssh-ed25519 ZaBdSg j1wG6GxL536GI98uQDjvd3k4NX9i6xJaTURsOeM8tmI | ||||
| omHmMEDCCjoCDb/CClty0crcLxyGgHUswr4HOP4L86k | ||||
| -> ssh-ed25519 MHZylw BS4N9FGQvoBFYMcUKZ/0fNAR5b8gRdEqdBahN4IjhWc | ||||
| ZnDyOGMiVn2zyKisDpHu5o9AFg+Sxsor09p1BpL3hQU | ||||
| -> ssh-ed25519 sIUg6g hGohSvdPUBmiD5XvGT5S8svHKeoX4iADR0wnTXBrvm4 | ||||
| q2kb1n46DQAceE0PpHwk32cycGur8eWGUwjyfp4o38M | ||||
| -> ssh-ed25519 TnanwQ 9eI4k/NX5NgWWsydOu0bi8OhBncIKS6xyMEzuJrYY1s | ||||
| dY4WyWbqcGS+RQUM391kGBlRXFzB5fIX+PpVQPvcD2I | ||||
| -> ssh-ed25519 ZgrTqA Hv1BMWICdw57RojY05L13liVfrg9qt6WxhiK6SAnqnc | ||||
| vveVXJsn4MVYTLX/HvKaofXWOeJ0IMdWSeDljKSlSwg | ||||
| -> ssh-ed25519 ZaBdSg iyNGSlaHdvTctpECP5qXFSO0gC0skd25gCidX8mJhXE | ||||
| 4lC4UIFuPimSfPuavLjhR94M5roDeco5yRDClI4P0V8 | ||||
| -> ssh-ed25519 MHZylw a8Ueer7YzQ1f4PPgedktuyNWa1r4cE3u2nDU61nC7UU | ||||
| SETxeXg59NOznOfuLvduM2tKUolThR+CNWVCAj4fahc | ||||
| -> ssh-ed25519 sIUg6g A/C7Vtugn4p3w7gc6s/ZBbTIUW2dOEcGwSVfm0kwY1c | ||||
| 66bSBWF+ZVKHvmEi+OEnfQF9m+7u+W0VnbDHxw9WY/Q | ||||
| -> ssh-ed25519 TnanwQ E2I98KMUGzMDiyJLUeZcLpb++1v8udmnONioiVmVzyk | ||||
| Sbc6bfi8VUyO6eBBkyv5DoEfVNd99K1G8NexeDmuDhA | ||||
| -> ssh-rsa gwJx0Q | ||||
| Hc+8CkU0zml1AMG2z4mxx8/0Yd0YlcdSkPgMqXk7TL+Pu7uJPLNfsxHDGKFKLeOJ | ||||
| uWeyFRJHXx3gOoGo2sQpMcInnU1PL6bNq6r86KeUruYDUMgxak8Pze9LFv9ZzsfY | ||||
| +nJ7u/kpSFvhRQR4J3cbwK3ZI2ezWHGi6vClGf+Orxt2k6I8WkwDPVC7+xeQDOFh | ||||
| pFa1V44OfcJXeSLEyioPKxB2LXBl30qcVcWiCMWyHt4GiITLovGKqYxrM1Q5jPXU | ||||
| Ty08vkYlgqGEOdvmE4LaBsZ/SnKukArUHykjstUp7bCqqVAaywy5zcDt9RhOnz3k | ||||
| tTSB2Gy5/reAD4NqbLb8Sw | ||||
| -> ssh-ed25519 YFIoHA 5dSh3gD/8VZAzoUqs0qhcPl91+i+Bf9et1DXXDukr2M | ||||
| 2GUCUGw0lqyJj9Doed75mG5ix3La9BjeLUd39ZiTeyg | ||||
| -> ssh-ed25519 KQfiow Xv1iY0dBtz3V8T5GyPET9BwqbX4Y4af7eecBY7y1Anc | ||||
| ts5ErCZqFcRTf6lLprZrr2np8o6BBGblRPrOh44UFNA | ||||
| -> ssh-ed25519 kScIxg G2Je9Qp1A9Zj9b5luvK2sJO1SWy2AZKGcM6EHKigPns | ||||
| bKIxxBdJ+DiRWuXRNDilOKxQJdVekzs9IwR7GiTireY | ||||
| -> ssh-ed25519 HzX1zw wMhENDQMUsij9CbQaxkVIglL6WBZlDeZbRLqm7otEAg | ||||
| gzlH0PS+wgoHm9RiJnOwJtxWdAILLHNGOd/lsk35vCE | ||||
| -> ssh-ed25519 KQfiow 3U/Gl7VGyBSCaQ06XLIatyCUsu/78MvyuyUXoSi3Djw | ||||
| HV+Dj3VpnCdzz7XuRfhfJGhAD+7Fv+5vb60VZI2/T/k | ||||
| -> ssh-ed25519 1o2X0w HsEk1SiUhTqOTAw6DminH+BAc5Y7Peogb3BuGpgB6FM | ||||
| Zm4j5robwQS5T2sBOiSNPncXkltdBgYfYu/d2qgKcQA | ||||
| -> ssh-ed25519 KQ5iUA hvAKzXWUKMyNaJxWuk2Ath21FI0UJUWVO8GkVS01iTw | ||||
| 8WGPzRRaxrVuX8gTe9+P//oM8Opk6tcVJbQ+WLTdzEg | ||||
| -> ssh-ed25519 AKGkDw 3ALLobyiLBam2jGvDTnvQnFDKwqMu6Sms6VK6A9jCSg | ||||
| LA1XgPi4EvZ+RYKaYyYVMThEu+edYyQyOccfX7arCco | ||||
| -> ssh-ed25519 0eS5+A L+MOMKygaYRXXslO2pp7smRudxO3SFCU1Y2OXxbjyyQ | ||||
| EScEV5/7m+HSNhvFYj1uOvKf/vTj/T5pSr62cWkEYyY | ||||
| -> ssh-ed25519 9/4Prw 1VFfT7FpfFEFfnx/Tf1VQYKvEbc+raAnveL7xckM+AM | ||||
| oYZ2WuJ0BE5T/j25EACfB/cjLCP9IElCnKla6aZPLD4 | ||||
| -> ssh-ed25519 gAk3+Q zhmxSdCJmIySnMINqbKxNjmVctS9eHX4rTKqC0z+xGc | ||||
| GSnqECoK+bj3aRWvQ2ALVV0VFznk7fSr77Vcv+oWpl0 | ||||
| -> ssh-ed25519 X6eGtQ 5xUEtBKxwQLtlmz4Ne05pjUsxeXFRZEn3rIEnk71tXI | ||||
| fG2mfswiyhZB9J69Y91zo0YocbDnftd2lIkv0knbqys | ||||
| -> ssh-ed25519 0ma8Cw o+sHqr3FeOdpdrSKMCFl6M0YypkFUklOuOcdTuxzjFg | ||||
| s6veJeLpYv4XcHGv/fvHTDBV2LzN4lkkgMiw9r3Tmh0 | ||||
| -> cFiHfJ[~-grease U^| y& | ||||
| eE+uq9nid3cWH7UO/044x6hCr/ZBZUwRIQIMi7X0yFDf4We54/kRGdA | ||||
| --- yja3ejJfODu7JOeNwFGq3l73whtWcDCBdqV3zM7R3Us | ||||
| ɠkޞ<EFBFBD>,%de<64>lmJ_E9%"<22>G<EFBFBD><47>7<EFBFBD><37>w<EFBFBD>r<EFBFBD><0F><>zj<7A>c@<0E><16>ڋ2<DA8B>JM	FSw<53><77>օJ<D685>Ǝ<05><><EFBFBD>{~E<><45><0F>}}!- | ||||
| vwnSvESPfLtlWVchHtsmPAYqUnSoKIjf16qwk6rKD976cDQt8TEQqKjbGExHNBZF | ||||
| hnXfPxLy4at1cJzPCVOsumGVdkTkGPhMkyOSTnzipGBA0hiFZ/YKmoqyl8MnOy9H | ||||
| RVd51JJLdmUUDUsVLdv8DEbYw2mTmLJsoum+LXi1oYHrYqhQvC2PhXH8b/jfn0En | ||||
| vYrzIxbFaJ/xw6o+T+4G/5d3DCX4fb9ccYHnLhv9GQWvQPH+wEfYkKBaxriur1ir | ||||
| 9gkE1kErSzemr0sND5NoZKkGqf4P4ear3Vnjtf1gg1Can3Fqutb0B9ou71RD111J | ||||
| SupcBHc0D7Kc47CTzI/V4w | ||||
| -> ssh-ed25519 YFIoHA HSIHZ70ZSLrbeieWFfRI8Syj5QVr3X3g3J68ZEsOSSg | ||||
| 8veYBdbZfkqQ/7YvpFeE7pjWR1hZ9HF4JfM5yPUdl3Y | ||||
| -> ssh-ed25519 KQfiow 4Ofzo/KS6qE+bb2O2l9p+Xl7sVSyYztBW1wy7e8aGCk | ||||
| gzeCLM85g+tSGYFAM3z03HVwyO67sriOVgL6uiOGWV0 | ||||
| -> ssh-ed25519 kScIxg MNZ5ZwjuGahkB/N3KlIzCwQjtenikYhCcqOqUsotG3c | ||||
| SvDAuGNWu1SG7EEQLJboFJ0VKEAbcc1rZbg9LCdxtyk | ||||
| -> ssh-ed25519 HzX1zw 9Z3XU4h4otPcP+3hx4gA3t3/T5RJAOyf/Lm/gWK8Y28 | ||||
| WEpitv/XIXxHg0Rmf2zibIq8Vrf01ieEPJ9teXgHp1g | ||||
| -> ssh-ed25519 KQfiow HF3fZ69+NwB+1tyZDoBb+vL7S0sAB4VtFbteA8l3myE | ||||
| EPE0dZ4HAsE2SLXT+BlDUrWGGNKlBUQZLYVKiOYwvs0 | ||||
| -> ssh-ed25519 1o2X0w NQodm0eoA8H57E1Lgt11GubQIXXn+9a9Ho79akD1FQ8 | ||||
| pG8VFyXUBsrTKEZnR/pCU5pZaIBu8s4l02tv27IFBO4 | ||||
| -> ssh-ed25519 KQ5iUA /XRx2bwU4u47q0pmFFjnmopgeAFDRcdwVUgiZvFZBEU | ||||
| hb7OR5qsZ2ctqoi9F9yoJiOSCMIEFhsKTxmTzTlNcgs | ||||
| -> ssh-ed25519 AKGkDw MDy7x7w+m12Un+WJzIjlT1sqFUqyMgvs5cUX96YtTBE | ||||
| 4idv3M2g8lkjGTXiH3zxR3sORP3K6OijlCF2vTlGDs0 | ||||
| -> ssh-ed25519 0eS5+A GxaSMOtNOuri6nFhtEmPCUAYO7ULTRgfhoSEhwsQhTA | ||||
| eFGFTZB2z4zBOp+yuU9ryvhNh25v5S5bT77+XYlZ3eo | ||||
| -> ssh-ed25519 9/4Prw 2dVb0418rDvJEJ8yYDm3+eofjwEA0r8tuloPN+VC01c | ||||
| uVjqjHdZCvfZJKZukaDT0m2SL1S0CMB/exuNeIEBlH4 | ||||
| -> ssh-ed25519 gAk3+Q 659Yfnz4QIdJCq1X3FxiDyL2F9QQEBSxyjnx+SCl3CI | ||||
| VuGpJwysc8y3Mq/HrIJP5DY1DdMJC7QlXTlyoCaWbzw | ||||
| -> ssh-ed25519 X6eGtQ hYe08q7Sofe8mdwVTCitTayJNbV9Tl9Bkt4RPexxMDU | ||||
| FhU5gPGYUi6DBMt2O1wY5uL25dyI3aGhXEFXfgyUgBQ | ||||
| -> ssh-ed25519 0ma8Cw z0Di7JjAJLIcQx2+B01JVBRbmh9fV1T0+Q6E8S+xGjw | ||||
| 507pjrUEDf7r/DY0zC3gGj78uifvpe13BHKVtetSPFw | ||||
| -> ssh-ed25519 Tp0Z1Q PMwAaVX/1envqO+cf93hMvw7skIHIwDHizPpjn3zLWk | ||||
| sNGxgzKWwS29pTBnv8YVQwGm7WzH0LnYXfqYjwsJ+gw | ||||
| --- 7ziHLKL/XsD7aJ+uEbNNNwxEC05vAINt+E5+Lvhm7oE | ||||
| <EFBFBD><15>;<3B>K<EFBFBD><4B><EFBFBD>Tc6L<08>$<03>s<04>O[3<><33><EFBFBD>U<EFBFBD><55><EFBFBD>t6<74>s	a S<>n<12><>#jE^qh<19><04>5eɈQA<><41><EFBFBD><13><>2<EFBFBD><15>I/ | ||||
							
								
								
									
										
											BIN
										
									
								
								nixos/secrets/gitea-runner-token.railbird-sf.age
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								nixos/secrets/gitea-runner-token.railbird-sf.age
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -1,50 +1,48 @@ | ||||
| age-encryption.org/v1 | ||||
| -> ssh-ed25519 ZgrTqA nxDhZDKcFwSoxR/i34N//ivTJDLC/11977XU4VmaWxg | ||||
| JEwXfBrRVtkOkrpmsU+Zk4YAIrxZkBbsTmUXOtOR6eo | ||||
| -> ssh-ed25519 ZaBdSg 22smm7JR4fwhhlb5sNo9Qrfyd70NZCDEQqQNrhfamzo | ||||
| aVwrulW5nWBqVLfB21A5wVdKYOpJq44venb3qXjpr+Y | ||||
| -> ssh-ed25519 MHZylw eOjkoAZZjqMKZgCH+XOsdX7QfOAh23Qh7byqgWLvbEg | ||||
| 2HUuAPBYmMwfyAD/ZKoYkwknPWwvldHpfHrOc8BMHXs | ||||
| -> ssh-ed25519 sIUg6g DTno5u3GShRGLl3O21bMAeworZSGPTHyawVkQUdOCX8 | ||||
| 1EKEyC0g0Bzdut5kj5+YcTVW+QqWxXX0INKHOh1yQmY | ||||
| -> ssh-ed25519 TnanwQ duKkCYjd1yIG4rRPWyN8KF7Ktc8yRa2t5urLGzOYqwA | ||||
| 72Q4lVsHbAAmxfxazFk1Uhd2WgY1tDtA3Bma81oyDQo | ||||
| -> ssh-ed25519 ZgrTqA gwgbZfsmN/IZSoLT93ftwBDJ9FMFkumWuDYLAdR5mDw | ||||
| wjVFV+RNqRUomklgh+/I+upUzOjIF7NbeHDG/ZfAkXU | ||||
| -> ssh-ed25519 ZaBdSg vfpZjIfCwFXEkEUrErLcCSigL4Uqm0/NZkIyzMkJmC4 | ||||
| NgGeogehq3w0AUawo9blKKMrr1HfwSseUndNSvA0cDw | ||||
| -> ssh-ed25519 MHZylw 9gx87i2+xptkEFAq4brfSa28StOcKHrBrQ6YdPrEXVw | ||||
| Wz0TkHL3865UNTalO5GLyla3eh5HO8CU1OpvmFnUz1Y | ||||
| -> ssh-ed25519 sIUg6g kXECNgiZ+7BenXVIvbioQwYb0Kni3uCAyHgRgbw11C4 | ||||
| +ky0U9p0KaAu35zSOSNHXPmHFqdIf8BGAveLDMxpeTU | ||||
| -> ssh-ed25519 TnanwQ G5nA7iVSLYTx4TE5Xb5G/69JKJ9qm8xpYq3xi4A7ZDE | ||||
| yMW2ny1+QuPB+xzSRxxdYN5bjKZiJVY04qN6W+V1Y3E | ||||
| -> ssh-rsa gwJx0Q | ||||
| U15JflZHy2YXgUL+YbLw21GGrjo9kUUGBIUy9zviyfRze2FsP/s64o4I5RcMHZQE | ||||
| fMeSZkZSECPW55EnyNXPP58B9afruHPttq0cA+8KhmvN92pTJFVW3B29NZvAmbg+ | ||||
| yw6k8m9CbTTNj1YAiPP4zoW5VA5bWB9vNsTC42RLN+mXvnk3jHhJiyQ77E0m6dsX | ||||
| gT6JePlb8iOySx6i90/b6PuFB23i2QFnyBUsGcwhU4VPqPcNEoXZwpS9ibbQoXYW | ||||
| Ce15tbkfjm7HffI8cnrnJh3HpO+3onoqfwJLSm7v1twGGN3neqJU31ywFPE5kvtA | ||||
| J53Ii0JuEjqghm9GaspfTQ | ||||
| -> ssh-ed25519 YFIoHA 44F44WcZamqz8iYwS4HQhqT1zNdUZDCI+Zfq1zlpGjQ | ||||
| dyroggIjVoJCFayVjmp2zN7m6s9uDECkXUL8XJQ9uFk | ||||
| -> ssh-ed25519 KQfiow /50omkmktdLNxaOHB3ImSrtL+wCtKQqVH8nGyo4Q8xE | ||||
| 90cGcqXOePnHjAhn262MeuMzn3odfKrgwsky1yE+6Hg | ||||
| -> ssh-ed25519 kScIxg j/12yl3KUndaxmFovvXeWvNjDiS4gLmTu60h091vFCE | ||||
| hscYo/JdGuH9jFiZl7qKP7nNwiBsTKwMgqLK1SLPXPM | ||||
| -> ssh-ed25519 HzX1zw /+sbKjdDKP7tzxD5Bi3KXLf/qKbIdXqkvgv5VVMtGgc | ||||
| kv7Bv79YUyVy2MpMECI5+1Z/jz9hKG+guAB3joIEF94 | ||||
| -> ssh-ed25519 KQfiow z+1XnwF0MvV1WoLMOm1y1SBFmMCuBs52bEHNOVWHrSI | ||||
| AV1Desi4VRies/yqXcSjISdxPGvKn8aWYTfDFPMyzEY | ||||
| -> ssh-ed25519 1o2X0w q/W93yDVRDYcazyOIlf8jUBHSNng0GgPsqZA7r3Mn2U | ||||
| NtlRyyH4mbAnTAWBRpf5PL4vLyk2wSxAobSkYMBBX+A | ||||
| -> ssh-ed25519 KQ5iUA 0RLXvcC+cuMFXGgQQnCBJhWQU6+PglxxQaxlZSqVNE0 | ||||
| 8WRPF58jm6m/gKubZgomqCZNpQoLA26fOzfY0Hqx3vI | ||||
| -> ssh-ed25519 AKGkDw Wi+UsCD95sykFp2c+5mGWGM1XgHxt7CAnSQR5vT8S2Y | ||||
| TPk8gkZkmhdZnNiI1Wo1yRGkMgQdzf12dLJCDHISCjY | ||||
| -> ssh-ed25519 0eS5+A Ip2KcVBtziu8Gtgz0ekmbk3G4yB4EUjUCQcaqXbQcjs | ||||
| t2y53xf2mEHGxFaeONMXa3/t+zGDCdQKb6RQecYfkmY | ||||
| -> ssh-ed25519 9/4Prw zkAdxlDmai9tSFu+a6a3jhoUnyxzZUpCiLgAyJ85uwY | ||||
| u+z5fSEzJtPvz7iEFFng4cn0WQJuMYO5zFsBCnXvXvs | ||||
| -> ssh-ed25519 gAk3+Q 6S8D1fDXLKPc9MvrnHbhMLqoY8f1W+yy9LrZq2345lY | ||||
| oSkGUfVxlqPnqS4sHqiywVg/cSu8rDiosw8KbXtlhn8 | ||||
| -> ssh-ed25519 X6eGtQ kCtmcfUdTp8vJ8rBFDDJeJmk7s/uhlRuvrk9fhvQzw4 | ||||
| lKwwGc+86muQv8dZ0BuivDHHR2vX/hXuhqDHNgq+/nA | ||||
| -> ssh-ed25519 0ma8Cw NAFySfIt7dQ3kTL73/7E1WzpOlcyd7PU1DyMsYWGnl4 | ||||
| JTZh0eM06/IOC8HNRxn5gF3KAlnBmmEUpxv5UFjuwks | ||||
| -> ZhDG9-grease > ~YTLl | ||||
| MzCy45d4My1EJc2k/SzhXa2v9geyu45HhXth4R/CMejeVSk+NuTfB1UhSp6iCErU | ||||
| eK4qPQoPCx2z1ihs5fQCC+lf55jE88+tP9aDqYPnTzXVPPHMNpDYLQYAow | ||||
| --- dVpM8R96RIKRuG6yQ672A543LxhU9ttuiSrbG4fcsvQ | ||||
| D4'Vp<56> | ||||
| Z<EFBFBD>x	YA`<60>x<EFBFBD><78> :<3A>S<EFBFBD>5u<35>W[<5B><>u<> | ||||
| IEv+jd2oOZskPWM/LWUb9ZLA8IzRfaBQTafgQyEzVoD7v8lbfpMKTI31ylxJQSvh | ||||
| d+gutl9xgGtVDHXjGdNKbDHwAVzYaz3IbvP+Vje9jtSqH6A0AU+1OqXeRzI3ZAux | ||||
| oBJlCEGZqSBspA8AhH3cv4ion0G6iC1wmqaIb9Nk/qnzfBvtE/cIpqErv19byVUj | ||||
| pZr5NviDXETV29Gz2HDyv3RsZ4wfJE/npebSu+ORakOH6PLRtnMpB4aKOensv31Y | ||||
| UJQMTHNuJRgPdxgSI0P9W/LaCSMT5vuXR4ETz4vEqDNzcFm1ekqfY8821/AbOtlD | ||||
| Q2c0zr2C+ayGW5zwGp2XTQ | ||||
| -> ssh-ed25519 YFIoHA UMEeywWPiRXx07jalhLcS4/TmK+gwg8nWdtBpM/IJzI | ||||
| 9SDhcDfTgwRi7HJ5zL9i8jHL6i00oi6y/qaTzsjb6uc | ||||
| -> ssh-ed25519 KQfiow furHqLazJ3qLEIod24dfGPfu6ie7zutEXDV0N2NGYDY | ||||
| Se5igVc1LJtobjLioH05RPtQfUh5jjYV/bRgU3RL4dY | ||||
| -> ssh-ed25519 kScIxg mBFDyzrNBg33LQAJMvlikmd7h0X9d7Eus/p86PF8mxU | ||||
| MCHgXOGu9AE83VulyxcPEwbfbiymqiZ9c6p3IqLzhak | ||||
| -> ssh-ed25519 HzX1zw dAgBHAtVniUDV5W/MGrQX1cQh+P+cpHErnxCMn/b8A0 | ||||
| zx0RxAMo2b6fzjx1U2hw/wHjz8dRXHcM+e20dXRkN98 | ||||
| -> ssh-ed25519 KQfiow NxL41InC5f7Za+/EIQT+z+vhzkkzQxOBRBqTe0J2U2c | ||||
| t0IJoVJ9Ap6P4D4kCM+TGgU2oKhTEpeiFktAQxM+C54 | ||||
| -> ssh-ed25519 1o2X0w ++MXOZdgCeKxiKyQ6mAiVz1i4dXnpyFSuhSq5hG3vVM | ||||
| KeMSC/Cb10lF2ZvdLS5JXRkOE6iEcLtju3I6YMRQoqU | ||||
| -> ssh-ed25519 KQ5iUA +5L7eIEu1RGoVXxpd/nJHi1/DIF82YCKtzt71mhKqRc | ||||
| +La1804HzEBjkHeQdRGboNwIj8NarvZ/SJG3Ua4y+Vo | ||||
| -> ssh-ed25519 AKGkDw Ru9l2BXa/LUZCn5DpMVDh4ca7w1JU2thmChLOeY8Ii0 | ||||
| GSua+XJoy3g9NNZ2qHstAbomR/3xKEAe6SOcn6g2Q/w | ||||
| -> ssh-ed25519 0eS5+A e2prXUG804KhjGO+rg/eXrZUQM73HxQ/BnN1vsHbuQU | ||||
| nIANuBAF2Tk7hWT9HJJ4uvUrPbtUhsBW59eOkVnK5IY | ||||
| -> ssh-ed25519 9/4Prw DOtRMtKN5Q1YFq8AFrH/37SJxaHoaZuTMa/JVzT2Bzk | ||||
| j+mawty5y3Ox2Nzp3TncHbR/rMmcmIQD5EfezhUUtWg | ||||
| -> ssh-ed25519 gAk3+Q mZVlRxtH9jV7N6/aoJ1je+jkxuF7sffcGsLiYwjReHw | ||||
| XOQKhZ60vBfHaO7u9Fkwy40po/jh/Y4/Yj/D4gRO0k0 | ||||
| -> ssh-ed25519 X6eGtQ 8+iFJD1esMa/3yuKAx8fZBEJ2SxLdrzXhqqkEicRvgQ | ||||
| R9jJ7vDcxA/sOSF329GW8d18Jzdwot/BpFEl/knraSE | ||||
| -> ssh-ed25519 0ma8Cw LgbM+4liQS3j9acMcFnnp9gi4Gzkq6Xtmrm4KQoO5hU | ||||
| TX50NCZoZpH4SzS7ZfkDbEcGO/A3dzRJXvtDqxjzsuk | ||||
| -> ssh-ed25519 Tp0Z1Q yHfAA3IRIM3rDcPNoV9qh1RU7g6LX9aelELZGXVt7Wc | ||||
| QIlWb0xzr+RpVwcyBqr8oRR4WrOz9st4fFSKNCEXCWE | ||||
| --- ztKYvZNf3AP9x0CiM2gtLQEIRHtkwAEgaBRHWJSZuKc | ||||
| @6<>ۑ34p<34>oq<6F>Dv<44>ub9}`<60>I<15>ɞ[Y+<2B>&<26>&n<>3<EFBFBD> | ||||
							
								
								
									
										48
									
								
								nixos/secrets/nextcloud-admin.age
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								nixos/secrets/nextcloud-admin.age
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | ||||
| age-encryption.org/v1 | ||||
| -> ssh-ed25519 ZgrTqA l1KhMBYmv+TZzBET8kptlZsQqzk3PWm4KA1YbQ7pLDw | ||||
| XQdF+ZjcWyWs1oprvb5J5GWL9qhQ2oyTiAHU580I9Us | ||||
| -> ssh-ed25519 ZaBdSg HpBQZKCjSZLWOgUhlZNBSQdEh4VqHyIRsnWeqOoNu1w | ||||
| olbfsFPUKa6n64WxIjqSfzEN0Sv69rkMem7l4BSdRO0 | ||||
| -> ssh-ed25519 MHZylw i3v/ahcgJ0eNpv+eyLcLW5HFbJgDxmILPwRIfYbfYSo | ||||
| gNFYiAJFaeTE2psIhpAOEbdh8qpNPkHhQ+JimwLWHMU | ||||
| -> ssh-ed25519 sIUg6g qhpWT0ZYGs7L9phprKuuTc5x3ONa5HxfJrml9hZXCDA | ||||
| bSUNBSgE4THO24IldTR6UDl1nibM6wJVhfQDNgXDHoQ | ||||
| -> ssh-ed25519 TnanwQ oIiKhCPi2Q6Aie4hdnMM+GD0X1AP+RRYX3MhPZr6mwg | ||||
| +eQAf9brHo6aFjChm0AhUcF9taFNqrwIITVanvAJBZI | ||||
| -> ssh-rsa gwJx0Q | ||||
| bPnrY1qe+cJIrAL66CjfIoHrwpyIsJ3hxMnjecNpbYwj0VD2FDy8oLknXvUs+Qr7 | ||||
| 9AVJXYnkJ2qP/KSxZe0Kq4yvuIVu30CcibMWdA+FbDSC+BGhkFuVMbn87ewujBZO | ||||
| yckIiiW0Z26mmBWTc2wOxJvQBsvNmEzJqt75g1SKjZYd4yD2ZHybLZkd5S2CRNnE | ||||
| P+9UZstX+ZGQT7N4xCaYi1nBn3ZyDx6QfUtWPK+W+ZBxCmeCWSKA6GdPhG3Xy/sD | ||||
| 7Emq3VQpFwByBzgno7u3XzhY+RgGDDWz9YnvieUPT7VloXnjD+2+CqiS5zYj4ueM | ||||
| 5VHE4pYUTczXWBe2kurwpg | ||||
| -> ssh-ed25519 YFIoHA zgTafEG44X/fXwXLIlogjs45fAjoEMtWwOH1bJiUXA0 | ||||
| vp/8r42Zr97CVwG5K9F8be5OUy9lAjqMC/86mgsHyok | ||||
| -> ssh-ed25519 KQfiow 0mtQJsqu9ilrlYIcxEURoPR4v26ovNb+xK3HsA67J3k | ||||
| sUGJ2uJXmDCzjWVGvD+kQq/k1Kjh1GWxalx66PdbRLo | ||||
| -> ssh-ed25519 kScIxg G/D+dmQhzFH8baIl1/LEcFm6Srag72DfUwMi2lU4FSI | ||||
| lUm3v86TvpXOCEOD7x2c6OQfglVlNpz3RJQKgLos4A0 | ||||
| -> ssh-ed25519 HzX1zw mOWnNPTDS2uWUhaBDh5W20sa6L8Sv82B/i5fyYtBg2I | ||||
| ml3ypIN6Hk9ZLWAHgeeX9Fl69cVo0quKKnIOzf0gtiA | ||||
| -> ssh-ed25519 KQfiow +KbirvF1s4PLCPVko1UuvGkPUWT4ysU7IURr61WBYFI | ||||
| EIEFzIrqBu0eF2qsJ0sNYWVLdxUVWhER05C//iU8Hik | ||||
| -> ssh-ed25519 1o2X0w SEi4GVg7eYsP4H5x+FzMWaHzQ10qYuD63DtlNbdtEjg | ||||
| hvVJMGz0mrfKYua9kfc+QfZgAqAapKlRoxmJQvX076g | ||||
| -> ssh-ed25519 KQ5iUA DH/T6YbQufZDEejYJwyTvxeR2dn/CaTm1i68Rh03yyU | ||||
| u3sMfE0YupucU58UVrCkEsVKPWCvxEfDDCvRhON0J+4 | ||||
| -> ssh-ed25519 AKGkDw N/s4jeBT7J8oTXqiJhfNRzUuxR9PTyGApTqCjERFH10 | ||||
| oxEicNoou7wTRuLra2lNHUGp6ZAVNMAV88X/UTdI16M | ||||
| -> ssh-ed25519 0eS5+A mJLNn95SfVF6fBBmPJHBxeGH74+hCbHVC3CHN3bcr1c | ||||
| mVc2Rsz6tXZlPGSMNNmmo4sbPN36we7YVy17mXkwKas | ||||
| -> ssh-ed25519 9/4Prw moIGBpA5A/k4RqRFbiESz4LjB57/e7CV4Usp0kJ+o1Q | ||||
| MCDzUd0ZM8jEFPkcHaYXcCBeJT7L6vkqfSlpZQ/sG5o | ||||
| -> ssh-ed25519 gAk3+Q DkXPTEBi/E6aZkDQeeXPMs/rhg+ZyipHQ5PfbrutMSk | ||||
| lOlrZmHIgLzUkMUYjWwVs7c3oR3xA3PEevT41nXkKcs | ||||
| -> ssh-ed25519 X6eGtQ FnKi617TVTcL4xNmWCiYdFZXqN46WaoGS9XUsR4cvSY | ||||
| STQh6M7mB15fSvndYx7wei1M/NLuKx7P1IGfjfzW+VY | ||||
| -> ssh-ed25519 0ma8Cw jNGzFMl5ln7nhFcmZkzLcMDlCliMTP0d9FI0pA0PaDQ | ||||
| sgMfIzoC4fi2aMvtvxNpifw2pXeJJtB/rI1Js8qZmlM | ||||
| -> ssh-ed25519 Tp0Z1Q 4H03FYzl4l7Qy96uo+WxUcpQiWWXdEPva8nPcIPg71w | ||||
| pza0c3a9aTnXFs/MT3wkORn6WUKQmxW/xqAaorZHmSA | ||||
| --- qteXhOgvLyIakAwNEcpK5Mtk0aERS+2hNZFT+bmE/HU | ||||
| <EFBFBD>Z<EFBFBD><EFBFBD>iCG(k<><6B>fa<66>?<3F><><EFBFBD>k<02><><EFBFBD><EFBFBD><EFBFBD>}<0F><15><> | ||||
| @@ -9,4 +9,6 @@ in | ||||
|   "gitea-runner-token.nixquick.age".publicKeys = keys.agenixKeys; | ||||
|   "gitea-runner-token.jimi-hendnix.age".publicKeys = keys.agenixKeys; | ||||
|   "gitea-runner-token.adele.age".publicKeys = keys.agenixKeys; | ||||
|   "gitea-runner-token.railbird-sf.age".publicKeys = keys.agenixKeys ++ keys.railbird-sf; | ||||
|   "nextcloud-admin.age".publicKeys = keys.agenixKeys; | ||||
| } | ||||
|   | ||||
| @@ -1,8 +1,9 @@ | ||||
| { config, pkgs, ... }: | ||||
| { | ||||
|   security.pam.sshAgentAuth.enable = true; | ||||
|   services.avahi = { | ||||
|     enable = true; | ||||
|     nssmdns = true; | ||||
|     nssmdns4 = true; | ||||
|     publish = { | ||||
|       enable = true; | ||||
|       domain = true; | ||||
| @@ -19,13 +20,15 @@ | ||||
|   services.openssh = { | ||||
|     enable = true; | ||||
|     settings = { | ||||
|       AllowAgentForwarding = true; | ||||
|       AllowTcpForwarding = true; | ||||
|       PasswordAuthentication = false; | ||||
|       X11Forwarding = true; | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   programs.ssh = { | ||||
|     forwardX11 = true; | ||||
|     forwardX11 = false; | ||||
|     setXAuthLocation = true; | ||||
|     knownHosts = { | ||||
|       github = { | ||||
|   | ||||
| @@ -1,2 +0,0 @@ | ||||
| #!/usr/bin/env sh | ||||
| sudo nixos-rebuild switch --flake '.#' --impure "$@" | ||||
| @@ -12,6 +12,11 @@ let | ||||
|     jay-lenovo-wsl = { id = "F3HW6DZ-B7BFACJ-SRAUM7Z-56TXQJ5-5WKZT5A-GKXAHVD-YLXFJ4M-G7OJQQC"; }; | ||||
|     jay-lenovo = { id = "AP5ZUKJ-QBVYWCN-DYHR3UB-JJXRWNI-CAORGYM-HWRKHEH-ZJSTRLN-PP5USQX"; }; | ||||
|     jimi-hendnix = { id = "55JWW5K-4NY5DKT-TR4MVPO-UNOMQKM-J7TYCRF-CCCZGPM-FVRKHID-JVFLAAV"; }; | ||||
|     railbird-sf = { id = "5F4FPJM-KRBFVIH-CTTB2NC-7CPVGAM-CONMH2Q-SQPRODO-CWKRFPF-HVN4AAD"; }; | ||||
|     dean = { id = "RIVW4FP-NZNGGGD-4ET26IC-R6CZHEU-4EBIDHX-U756VWB-W7EM3LE-3YQ6YA3"; }; | ||||
|     mixos = { id = "7DMMUDT-CO33EMS-LQW65MX-3BVYDBT-ZZWDJC6-SWEF6SW-ICUMWOE-ZC4IBQK"; }; | ||||
|     strixi-minaj-wsl = { id = "DOAEFFI-W6EZY3K-GDUHDLX-6DQPVFC-XU3G65X-5KX6RKK-EMF7ZT7-YKKKOAM"; }; | ||||
|     strixi-minaj = { id = "IF76WOS-WVYFAQG-ZZMIT3R-ZR6EQQH-YQP3FGZ-BJ3LJKO-56FK2XA-UREADQM"; }; | ||||
|   }; | ||||
|   allDevices = builtins.attrNames devices; | ||||
| in | ||||
| @@ -21,8 +26,15 @@ makeEnable config "modules.syncthing" true { | ||||
|       chown -R syncthing:syncthing /var/lib/syncthing | ||||
|       chmod -R 2770 /var/lib/syncthing | ||||
|       mkdir -p /var/lib/syncthing/sync | ||||
|       mkdir -p /var/lib/syncthing/railbird | ||||
|     ''; | ||||
|   }; | ||||
|   systemd.services.syncthing = { | ||||
|     serviceConfig = { | ||||
|       AmbientCapabilities = "CAP_CHOWN"; | ||||
|       CapabilityBoundingSet = "CAP_CHOWN"; | ||||
|     }; | ||||
|   }; | ||||
|   services.syncthing = { | ||||
|     enable = true; | ||||
|     settings = { | ||||
| @@ -31,6 +43,13 @@ makeEnable config "modules.syncthing" true { | ||||
|         sync = { | ||||
|           path = "~/sync"; | ||||
|           devices = allDevices; | ||||
|           ignorePerms = true; | ||||
|           copyOwnershipFromParent = true; | ||||
|         }; | ||||
|         railbird = { | ||||
|           path = "~/railbird"; | ||||
|           devices = allDevices; | ||||
|           ignorePerms = true; | ||||
|           copyOwnershipFromParent = true; | ||||
|         }; | ||||
|       }; | ||||
|   | ||||
							
								
								
									
										7
									
								
								nixos/user-specific.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								nixos/user-specific.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| { | ||||
|   home-manager.users.micah = {pkgs, ...}: { | ||||
|     home.packages = [ | ||||
|       pkgs.neovim | ||||
|     ]; | ||||
|   }; | ||||
| } | ||||
| @@ -1,4 +1,4 @@ | ||||
| { pkgs, realUsers, forEachUser, keys, ... }: | ||||
| { pkgs, keys, inputs, system, ... }: | ||||
| let | ||||
|   extraGroups = [ | ||||
|     "audio" | ||||
| @@ -27,35 +27,36 @@ in | ||||
|       extraGroups = [ "syncthing" "wheel" ]; | ||||
|       home = "/var/lib/syncthing"; | ||||
|       createHome = true; | ||||
|       openssh.authorizedKeys.keys = [giteaSecret] ++ kanivanKeys; | ||||
|     }; | ||||
|     ivanm = userDefaults // { | ||||
|       extraGroups = extraGroupsWithWheel; | ||||
|       name = "ivanm"; | ||||
|       openssh.authorizedKeys.keys = kanivanKeys; | ||||
|     }; | ||||
|     imalison = userDefaults // { | ||||
|       extraGroups = extraGroupsWithWheel; | ||||
|       name = "imalison"; | ||||
|       shell = pkgs.zsh; | ||||
|       openssh.authorizedKeys.keys = kanivanKeys; | ||||
|     }; | ||||
|     kat = userDefaults // { | ||||
|       extraGroups = extraGroupsWithWheel; | ||||
|       name = "kat"; | ||||
|       shell = pkgs.zsh; | ||||
|       openssh.authorizedKeys.keys = kanivanKeys; | ||||
|     }; | ||||
|     dean = userDefaults // { | ||||
|       extraGroups = extraGroupsWithWheel; | ||||
|       name = "dean"; | ||||
|       shell = pkgs.zsh; | ||||
|       openssh.authorizedKeys.keys = kanivanKeys ++ deanKeys; | ||||
|     }; | ||||
|     will = userDefaults // { | ||||
|       extraGroups = extraGroupsWithWheel; | ||||
|       name = "will"; | ||||
|       shell = pkgs.zsh; | ||||
|       openssh.authorizedKeys.keys = kanivanKeys ++ willKeys; | ||||
|     }; | ||||
|     alex = userDefaults // { | ||||
|       extraGroups = extraGroupsWithWheel; | ||||
|       name = "alex"; | ||||
|       shell = pkgs.zsh; | ||||
|       openssh.authorizedKeys.keys = kanivanKeys ++ alexKeys; | ||||
|     }; | ||||
|     loewy = userDefaults // { | ||||
| @@ -73,13 +74,30 @@ in | ||||
|       name = "andy"; | ||||
|       openssh.authorizedKeys.keys = kanivanKeys ++ andyKeys; | ||||
|     }; | ||||
|     micah = userDefaults // { | ||||
|       inherit extraGroups; | ||||
|       name = "micah"; | ||||
|       openssh.authorizedKeys.keys = kanivanKeys ++ micahKeys; | ||||
|     }; | ||||
|     unprivileged = userDefaults // { | ||||
|       extraGroups = ["syncthing"]; | ||||
|       name = "unprivileged"; | ||||
|       openssh.authorizedKeys.keys = [giteaSecret] ++ kanivanKeys; | ||||
|     }; | ||||
|     ben = userDefaults // { | ||||
|       inherit extraGroups; | ||||
|       name = "ben"; | ||||
|       openssh.authorizedKeys.keys = benKeys ++ kanivanKeys; | ||||
|     }; | ||||
|     railbird = userDefaults // { | ||||
|       inherit extraGroups; | ||||
|       name = "railbird"; | ||||
|       openssh.authorizedKeys.keys = inputs.railbird-secrets.keys.railbirdDevKeys; | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   nix.settings.trusted-users = realUsers; | ||||
|   nix.sshServe = { | ||||
|     enable = true; | ||||
|     keys = keys.allKeys; | ||||
|   }; | ||||
|  | ||||
|   home-manager.users = forEachUser (import ./home-manager.nix); | ||||
| } | ||||
|   | ||||
							
								
								
									
										7
									
								
								nixos/vscode.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								nixos/vscode.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| { inputs, config, makeEnable, forEachUser, ... }: | ||||
| makeEnable config "modules.vscode" true { | ||||
|   home-manager.users = forEachUser { | ||||
|     imports = [inputs.vscode-server.homeModules.default]; | ||||
|     services.vscode-server.enable = true; | ||||
|   }; | ||||
| } | ||||
| @@ -7,15 +7,16 @@ makeEnable config "modules.wsl" false { | ||||
|   modules.base.enable = false; | ||||
|   modules.desktop.enable = false; | ||||
|   modules.xmonad.enable = false; | ||||
|   modules.plasma.enable = false; | ||||
|  | ||||
|   # Update timezone automatically | ||||
|   services.tzupdate.enable = true; | ||||
|  | ||||
|   wsl.wslConf.automount.root = "/mnt"; | ||||
|  | ||||
|   wsl = { | ||||
|     enable = true; | ||||
|     automountPath = "/mnt"; | ||||
|     startMenuLaunchers = true; | ||||
|     nativeSystemd = true; | ||||
|     docker-native.enable = true; | ||||
|   }; | ||||
| } | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| { config, pkgs, options, inputs, forEachUser, makeEnable, ... }: | ||||
| { config, pkgs, inputs, forEachUser, makeEnable, ... }: | ||||
| makeEnable config "modules.xmonad" true  { | ||||
|   nixpkgs.overlays = with inputs; [ | ||||
|     xmonad.overlay | ||||
| @@ -104,7 +104,6 @@ makeEnable config "modules.xmonad" true  { | ||||
|       }; | ||||
|  | ||||
|       settings = { | ||||
|         inactive-dim = 0.2; | ||||
|         focus-exclude = ["class_g ?= 'rofi'" "class_g ?= 'Steam'"]; | ||||
|         rounded-corners-exclude = [ | ||||
|           "! name~=''" # Qtile == empty wm_class.. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user