diff --git a/.drone.yml b/.drone.yml
index 4cf4b3b2..23805095 100644
--- a/.drone.yml
+++ b/.drone.yml
@@ -1,3 +1,92 @@
+---
+kind: pipeline
+type: docker
+name: Upstreaming
+
+steps:
+ - name: "Sync 'devos' branch with upstream"
+ image: alpine/git
+ when:
+ event:
+ - cron
+ cron:
+ - sync-main-with-upstream
+ environment:
+ GITEA_SSH_KEY:
+ from_secret: gitea_ssh_key
+ commands:
+ - ./.drone/setup_ssh.sh
+ - git remote add devos git@git.b12f.io:pub-solar/devos
+ - git remote set-url origin git@git.b12f.io:pub-solar/os
+ - git fetch --all
+ - git checkout -b devos --track origin/devos
+ - git merge -X theirs devos/main
+ - git push origin devos
+ - git remote set-url origin https://git.b12f.io/pub-solar/os.git
+
+ - name: "Sync $BRANCH with upstream"
+ image: alpine/git
+ when:
+ event:
+ - cron
+ cron:
+ - sync-main-with-upstream
+ - sync-b12f-with-main
+ - sync-teutat3s-with-main
+ environment:
+ GITEA_SSH_KEY:
+ from_secret: gitea_ssh_key
+ commands:
+ - git fetch origin
+ - git checkout origin/main
+ - ./.drone/setup_ssh.sh
+ - git remote set-url origin git@git.b12f.io:pub-solar/os
+ - git fetch --all
+ - ./.drone/upstream-branch.sh
+
+ - name: "Open pull request for failed merge"
+ image: nixery.dev/shell/tea
+ when:
+ status:
+ - failure
+ event:
+ - cron
+ cron:
+ - sync-main-with-upstream
+ - sync-b12f-with-main
+ - sync-teutat3s-with-main
+ environment:
+ TEA_CONFIG:
+ from_secret: tea_config
+ commands:
+ - mkdir -p ~/.config/tea
+ - echo "$$TEA_CONFIG" > ~/.config/tea/config.yml
+ - tea pulls create --base main --head devos
+
+ - name: "Notify matrix"
+ image: plugins/matrix
+ when:
+ status:
+ - failure
+ event:
+ - cron
+ cron:
+ - sync-main-with-upstream
+ - sync-b12f-with-main
+ - sync-teutat3s-with-main
+ settings:
+ homeserver: https://matrix.pub.solar
+ roomid: dfQBqwkhIzrFjMSsxy:pub.solar
+ username:
+ from_secret: matrix_username
+ password:
+ from_secret: matrix_password
+ template: "Upstreaming {{ build.status }} [{{ build.branch }}#{{ truncate build.commit 8 }}]({{ build.link }}) by {{ build.author }}. [Pull requests](https://git.b12f.io/pub-solar/os/pulls)"
+
+trigger:
+ event:
+ - cron
+
---
kind: pipeline
type: docker
@@ -9,77 +98,15 @@ steps:
when:
event:
- pull_request
+ - tag
environment:
NIX_FLAGS: "--print-build-logs --verbose"
commands:
- 'echo DEBUG: Using NIX_FLAGS: $NIX_FLAGS'
- - nix $$NIX_FLAGS develop --command nix flake show
- - nix $$NIX_FLAGS build ".#nixosConfigurations.PubSolarOS.config.system.build.toplevel"
-
----
-kind: pipeline
-type: exec
-name: Tests
-
-steps:
- - name: "Tests"
- environment:
- NIX_FLAGS: "--print-build-logs --verbose"
- commands:
- - 'echo DEBUG: Using NIX_FLAGS: $NIX_FLAGS'
- - nix $$NIX_FLAGS build ".#checks.x86_64-linux.customTestFor-PubSolarOS-firstTest"
- - nix-store --read-log result
- nix $$NIX_FLAGS flake check
+ - nix $$NIX_FLAGS build ".#nixosConfigurations.PubSolarOS.config.system.build.toplevel"
- nix $$NIX_FLAGS develop --command echo OK
-
- - name: "Upload artifacts"
- environment:
- TRITON_DONT_SOURCE_PROFILE: 1
- PRIVATE_SSH_KEY:
- from_secret: private_ssh_key
- MANTA_USER: pub_solar
- MANTA_URL: https://eu-central.manta.greenbaum.cloud
- MANTA_KEY_ID: "5d:5f:3d:22:8d:37:1f:e6:d6:ab:06:18:d9:a2:04:67"
- commands:
- - export TARGET_DIR="ci/$${DRONE_REPO}/$${DRONE_BUILD_NUMBER}"
- - echo env var TARGET_DIR is set to $$TARGET_DIR
- - "mkdir ~/.ssh && chmod 700 ~/.ssh"
- - echo "$$PRIVATE_SSH_KEY" > ~/.ssh/id_ed25519 && chmod 600 ~/.ssh/id_ed25519
- - nix flake new --template "git+https://git.greenbaum.cloud/dev/tritonshell?ref=main" ./tritonshell
- - git add tritonshell
- - cd tritonshell
- - nix develop --command mput -p -f ../result/foot_wayland_info.png ~~/public/$${TARGET_DIR}/foot_wayland_info.png
- - nix develop --command mput -p -f ../result/test-wayland.out ~~/public/$${TARGET_DIR}/test-wayland.out
-
-trigger:
- ref:
- - refs/tags/v*
- - refs/tags/t*
-
----
-kind: pipeline
-type: docker
-name: Notification
-
-steps:
- - name: "Notify matrix"
- image: plugins/matrix
- settings:
- homeserver: https://matrix.pub.solar
- roomid: dfQBqwkhIzrFjMSsxy:pub.solar
- username:
- from_secret: matrix_username
- password:
- from_secret: matrix_password
- template: "Test run triggered by tag: {{ build.tag }}. Test run exit status: {{ build.status }}. Artifacts uploaded to Manta: https://eu-central.manta.greenbaum.cloud/pub_solar/public/ci/{{ repo.Owner }}/{{ repo.Name }}/{{ build.number }}/foot_wayland_info.png"
-
-depends_on:
- - Tests
-
-trigger:
- ref:
- - refs/tags/v*
- - refs/tags/t*
+ - nix $$NIX_FLAGS develop --command bud --help
---
kind: pipeline
@@ -89,55 +116,41 @@ name: Publish ISO
steps:
- name: "Build ISO"
image: docker.nix-community.org/nixpkgs/nix-flakes:latest
- environment:
- NIX_FLAGS: "--print-build-logs --verbose"
volumes:
- name: file-exchange
path: /var/nix/iso-cache
commands:
- |
- nix $$NIX_FLAGS build \
- '.#nixosConfigurations.bootstrap.config.system.build.isoImage'
- - cp $(readlink -f result)/iso/PubSolarOS*.iso /var/nix/iso-cache/
- - nix shell nixpkgs#findutils
- - cd /var/nix/iso-cache/
- - export ISO_NAME=$(find . -name '*.iso' -printf "%f\n")
- - sha256sum $ISO_NAME > $ISO_NAME.sha256
- - ln -s $ISO_NAME PubSolarOS-latest.iso
- - cp $ISO_NAME.sha256 PubSolarOS-latest.iso.sha256
- - nix run nixpkgs#gnused -- --in-place "s/$ISO_NAME/PubSolarOS-latest.iso/" PubSolarOS-latest.iso.sha256
+ nix --print-build-logs --verbose \
+ develop --command \
+ bud build bootstrap bootstrapIso
+ - cp $(readlink -f result)/iso/*.iso /var/nix/iso-cache/
- name: "Publish ISO"
- # custom drone-scp image, source: https://git.b12f.io/pub-solar/drone-scp/
- # docker build --tag registry.greenbaum.cloud/library/drone-scp:v1.6.5 --file ./docker/Dockerfile.linux.amd64 .
- image: registry.greenbaum.cloud/library/drone-scp:v1.6.5
+ image: appleboy/drone-scp
volumes:
- name: file-exchange
path: /var/nix/iso-cache
settings:
host:
- from_secret: iso_web_ssh_host
+ from_secret: ssh_host
user:
- from_secret: iso_web_ssh_user
+ from_secret: ssh_user
port:
- from_secret: iso_web_ssh_port
+ from_secret: ssh_port
key:
- from_secret: iso_web_ssh_key
- target: /srv/os/download
+ from_secret: ssh_key
+ target: /srv/os
source:
- /var/nix/iso-cache/*.iso
- - /var/nix/iso-cache/*.iso.sha256
- unlink_first: true
strip_components: 3
depends_on:
- Check
trigger:
- branch:
- - main
event:
- - push
+ - tag
volumes:
- name: file-exchange
@@ -145,6 +158,6 @@ volumes:
---
kind: signature
-hmac: 3e6a89e903e214f21d488eba82863683b130ef6dbc2dc352377d4fd94ab3cd0c
+hmac: bdbefb07b97dc8efc44d8eb36ee4d1bb89eec3b7255b49929e126e86a4b4a788
...
diff --git a/LICENSE.md b/LICENSE.md
deleted file mode 100644
index cba6f6a1..00000000
--- a/LICENSE.md
+++ /dev/null
@@ -1,660 +0,0 @@
-### GNU AFFERO GENERAL PUBLIC LICENSE
-
-Version 3, 19 November 2007
-
-Copyright (C) 2007 Free Software Foundation, Inc.
-
-
-Everyone is permitted to copy and distribute verbatim copies of this
-license document, but changing it is not allowed.
-
-### Preamble
-
-The GNU Affero General Public License is a free, copyleft license for
-software and other kinds of works, specifically designed to ensure
-cooperation with the community in the case of network server software.
-
-The licenses for most software and other practical works are designed
-to take away your freedom to share and change the works. By contrast,
-our General Public Licenses are intended to guarantee your freedom to
-share and change all versions of a program--to make sure it remains
-free software for all its users.
-
-When we speak of free software, we are referring to freedom, not
-price. Our General Public Licenses are designed to make sure that you
-have the freedom to distribute copies of free software (and charge for
-them if you wish), that you receive source code or can get it if you
-want it, that you can change the software or use pieces of it in new
-free programs, and that you know you can do these things.
-
-Developers that use our General Public Licenses protect your rights
-with two steps: (1) assert copyright on the software, and (2) offer
-you this License which gives you legal permission to copy, distribute
-and/or modify the software.
-
-A secondary benefit of defending all users' freedom is that
-improvements made in alternate versions of the program, if they
-receive widespread use, become available for other developers to
-incorporate. Many developers of free software are heartened and
-encouraged by the resulting cooperation. However, in the case of
-software used on network servers, this result may fail to come about.
-The GNU General Public License permits making a modified version and
-letting the public access it on a server without ever releasing its
-source code to the public.
-
-The GNU Affero General Public License is designed specifically to
-ensure that, in such cases, the modified source code becomes available
-to the community. It requires the operator of a network server to
-provide the source code of the modified version running there to the
-users of that server. Therefore, public use of a modified version, on
-a publicly accessible server, gives the public access to the source
-code of the modified version.
-
-An older license, called the Affero General Public License and
-published by Affero, was designed to accomplish similar goals. This is
-a different license, not a version of the Affero GPL, but Affero has
-released a new version of the Affero GPL which permits relicensing
-under this license.
-
-The precise terms and conditions for copying, distribution and
-modification follow.
-
-### TERMS AND CONDITIONS
-
-#### 0. Definitions.
-
-"This License" refers to version 3 of the GNU Affero General Public
-License.
-
-"Copyright" also means copyright-like laws that apply to other kinds
-of works, such as semiconductor masks.
-
-"The Program" refers to any copyrightable work licensed under this
-License. Each licensee is addressed as "you". "Licensees" and
-"recipients" may be individuals or organizations.
-
-To "modify" a work means to copy from or adapt all or part of the work
-in a fashion requiring copyright permission, other than the making of
-an exact copy. The resulting work is called a "modified version" of
-the earlier work or a work "based on" the earlier work.
-
-A "covered work" means either the unmodified Program or a work based
-on the Program.
-
-To "propagate" a work means to do anything with it that, without
-permission, would make you directly or secondarily liable for
-infringement under applicable copyright law, except executing it on a
-computer or modifying a private copy. Propagation includes copying,
-distribution (with or without modification), making available to the
-public, and in some countries other activities as well.
-
-To "convey" a work means any kind of propagation that enables other
-parties to make or receive copies. Mere interaction with a user
-through a computer network, with no transfer of a copy, is not
-conveying.
-
-An interactive user interface displays "Appropriate Legal Notices" to
-the extent that it includes a convenient and prominently visible
-feature that (1) displays an appropriate copyright notice, and (2)
-tells the user that there is no warranty for the work (except to the
-extent that warranties are provided), that licensees may convey the
-work under this License, and how to view a copy of this License. If
-the interface presents a list of user commands or options, such as a
-menu, a prominent item in the list meets this criterion.
-
-#### 1. Source Code.
-
-The "source code" for a work means the preferred form of the work for
-making modifications to it. "Object code" means any non-source form of
-a work.
-
-A "Standard Interface" means an interface that either is an official
-standard defined by a recognized standards body, or, in the case of
-interfaces specified for a particular programming language, one that
-is widely used among developers working in that language.
-
-The "System Libraries" of an executable work include anything, other
-than the work as a whole, that (a) is included in the normal form of
-packaging a Major Component, but which is not part of that Major
-Component, and (b) serves only to enable use of the work with that
-Major Component, or to implement a Standard Interface for which an
-implementation is available to the public in source code form. A
-"Major Component", in this context, means a major essential component
-(kernel, window system, and so on) of the specific operating system
-(if any) on which the executable work runs, or a compiler used to
-produce the work, or an object code interpreter used to run it.
-
-The "Corresponding Source" for a work in object code form means all
-the source code needed to generate, install, and (for an executable
-work) run the object code and to modify the work, including scripts to
-control those activities. However, it does not include the work's
-System Libraries, or general-purpose tools or generally available free
-programs which are used unmodified in performing those activities but
-which are not part of the work. For example, Corresponding Source
-includes interface definition files associated with source files for
-the work, and the source code for shared libraries and dynamically
-linked subprograms that the work is specifically designed to require,
-such as by intimate data communication or control flow between those
-subprograms and other parts of the work.
-
-The Corresponding Source need not include anything that users can
-regenerate automatically from other parts of the Corresponding Source.
-
-The Corresponding Source for a work in source code form is that same
-work.
-
-#### 2. Basic Permissions.
-
-All rights granted under this License are granted for the term of
-copyright on the Program, and are irrevocable provided the stated
-conditions are met. This License explicitly affirms your unlimited
-permission to run the unmodified Program. The output from running a
-covered work is covered by this License only if the output, given its
-content, constitutes a covered work. This License acknowledges your
-rights of fair use or other equivalent, as provided by copyright law.
-
-You may make, run and propagate covered works that you do not convey,
-without conditions so long as your license otherwise remains in force.
-You may convey covered works to others for the sole purpose of having
-them make modifications exclusively for you, or provide you with
-facilities for running those works, provided that you comply with the
-terms of this License in conveying all material for which you do not
-control copyright. Those thus making or running the covered works for
-you must do so exclusively on your behalf, under your direction and
-control, on terms that prohibit them from making any copies of your
-copyrighted material outside their relationship with you.
-
-Conveying under any other circumstances is permitted solely under the
-conditions stated below. Sublicensing is not allowed; section 10 makes
-it unnecessary.
-
-#### 3. Protecting Users' Legal Rights From Anti-Circumvention Law.
-
-No covered work shall be deemed part of an effective technological
-measure under any applicable law fulfilling obligations under article
-11 of the WIPO copyright treaty adopted on 20 December 1996, or
-similar laws prohibiting or restricting circumvention of such
-measures.
-
-When you convey a covered work, you waive any legal power to forbid
-circumvention of technological measures to the extent such
-circumvention is effected by exercising rights under this License with
-respect to the covered work, and you disclaim any intention to limit
-operation or modification of the work as a means of enforcing, against
-the work's users, your or third parties' legal rights to forbid
-circumvention of technological measures.
-
-#### 4. Conveying Verbatim Copies.
-
-You may convey verbatim copies of the Program's source code as you
-receive it, in any medium, provided that you conspicuously and
-appropriately publish on each copy an appropriate copyright notice;
-keep intact all notices stating that this License and any
-non-permissive terms added in accord with section 7 apply to the code;
-keep intact all notices of the absence of any warranty; and give all
-recipients a copy of this License along with the Program.
-
-You may charge any price or no price for each copy that you convey,
-and you may offer support or warranty protection for a fee.
-
-#### 5. Conveying Modified Source Versions.
-
-You may convey a work based on the Program, or the modifications to
-produce it from the Program, in the form of source code under the
-terms of section 4, provided that you also meet all of these
-conditions:
-
-- a) The work must carry prominent notices stating that you modified
- it, and giving a relevant date.
-- b) The work must carry prominent notices stating that it is
- released under this License and any conditions added under
- section 7. This requirement modifies the requirement in section 4
- to "keep intact all notices".
-- c) You must license the entire work, as a whole, under this
- License to anyone who comes into possession of a copy. This
- License will therefore apply, along with any applicable section 7
- additional terms, to the whole of the work, and all its parts,
- regardless of how they are packaged. This License gives no
- permission to license the work in any other way, but it does not
- invalidate such permission if you have separately received it.
-- d) If the work has interactive user interfaces, each must display
- Appropriate Legal Notices; however, if the Program has interactive
- interfaces that do not display Appropriate Legal Notices, your
- work need not make them do so.
-
-A compilation of a covered work with other separate and independent
-works, which are not by their nature extensions of the covered work,
-and which are not combined with it such as to form a larger program,
-in or on a volume of a storage or distribution medium, is called an
-"aggregate" if the compilation and its resulting copyright are not
-used to limit the access or legal rights of the compilation's users
-beyond what the individual works permit. Inclusion of a covered work
-in an aggregate does not cause this License to apply to the other
-parts of the aggregate.
-
-#### 6. Conveying Non-Source Forms.
-
-You may convey a covered work in object code form under the terms of
-sections 4 and 5, provided that you also convey the machine-readable
-Corresponding Source under the terms of this License, in one of these
-ways:
-
-- a) Convey the object code in, or embodied in, a physical product
- (including a physical distribution medium), accompanied by the
- Corresponding Source fixed on a durable physical medium
- customarily used for software interchange.
-- b) Convey the object code in, or embodied in, a physical product
- (including a physical distribution medium), accompanied by a
- written offer, valid for at least three years and valid for as
- long as you offer spare parts or customer support for that product
- model, to give anyone who possesses the object code either (1) a
- copy of the Corresponding Source for all the software in the
- product that is covered by this License, on a durable physical
- medium customarily used for software interchange, for a price no
- more than your reasonable cost of physically performing this
- conveying of source, or (2) access to copy the Corresponding
- Source from a network server at no charge.
-- c) Convey individual copies of the object code with a copy of the
- written offer to provide the Corresponding Source. This
- alternative is allowed only occasionally and noncommercially, and
- only if you received the object code with such an offer, in accord
- with subsection 6b.
-- d) Convey the object code by offering access from a designated
- place (gratis or for a charge), and offer equivalent access to the
- Corresponding Source in the same way through the same place at no
- further charge. You need not require recipients to copy the
- Corresponding Source along with the object code. If the place to
- copy the object code is a network server, the Corresponding Source
- may be on a different server (operated by you or a third party)
- that supports equivalent copying facilities, provided you maintain
- clear directions next to the object code saying where to find the
- Corresponding Source. Regardless of what server hosts the
- Corresponding Source, you remain obligated to ensure that it is
- available for as long as needed to satisfy these requirements.
-- e) Convey the object code using peer-to-peer transmission,
- provided you inform other peers where the object code and
- Corresponding Source of the work are being offered to the general
- public at no charge under subsection 6d.
-
-A separable portion of the object code, whose source code is excluded
-from the Corresponding Source as a System Library, need not be
-included in conveying the object code work.
-
-A "User Product" is either (1) a "consumer product", which means any
-tangible personal property which is normally used for personal,
-family, or household purposes, or (2) anything designed or sold for
-incorporation into a dwelling. In determining whether a product is a
-consumer product, doubtful cases shall be resolved in favor of
-coverage. For a particular product received by a particular user,
-"normally used" refers to a typical or common use of that class of
-product, regardless of the status of the particular user or of the way
-in which the particular user actually uses, or expects or is expected
-to use, the product. A product is a consumer product regardless of
-whether the product has substantial commercial, industrial or
-non-consumer uses, unless such uses represent the only significant
-mode of use of the product.
-
-"Installation Information" for a User Product means any methods,
-procedures, authorization keys, or other information required to
-install and execute modified versions of a covered work in that User
-Product from a modified version of its Corresponding Source. The
-information must suffice to ensure that the continued functioning of
-the modified object code is in no case prevented or interfered with
-solely because modification has been made.
-
-If you convey an object code work under this section in, or with, or
-specifically for use in, a User Product, and the conveying occurs as
-part of a transaction in which the right of possession and use of the
-User Product is transferred to the recipient in perpetuity or for a
-fixed term (regardless of how the transaction is characterized), the
-Corresponding Source conveyed under this section must be accompanied
-by the Installation Information. But this requirement does not apply
-if neither you nor any third party retains the ability to install
-modified object code on the User Product (for example, the work has
-been installed in ROM).
-
-The requirement to provide Installation Information does not include a
-requirement to continue to provide support service, warranty, or
-updates for a work that has been modified or installed by the
-recipient, or for the User Product in which it has been modified or
-installed. Access to a network may be denied when the modification
-itself materially and adversely affects the operation of the network
-or violates the rules and protocols for communication across the
-network.
-
-Corresponding Source conveyed, and Installation Information provided,
-in accord with this section must be in a format that is publicly
-documented (and with an implementation available to the public in
-source code form), and must require no special password or key for
-unpacking, reading or copying.
-
-#### 7. Additional Terms.
-
-"Additional permissions" are terms that supplement the terms of this
-License by making exceptions from one or more of its conditions.
-Additional permissions that are applicable to the entire Program shall
-be treated as though they were included in this License, to the extent
-that they are valid under applicable law. If additional permissions
-apply only to part of the Program, that part may be used separately
-under those permissions, but the entire Program remains governed by
-this License without regard to the additional permissions.
-
-When you convey a copy of a covered work, you may at your option
-remove any additional permissions from that copy, or from any part of
-it. (Additional permissions may be written to require their own
-removal in certain cases when you modify the work.) You may place
-additional permissions on material, added by you to a covered work,
-for which you have or can give appropriate copyright permission.
-
-Notwithstanding any other provision of this License, for material you
-add to a covered work, you may (if authorized by the copyright holders
-of that material) supplement the terms of this License with terms:
-
-- a) Disclaiming warranty or limiting liability differently from the
- terms of sections 15 and 16 of this License; or
-- b) Requiring preservation of specified reasonable legal notices or
- author attributions in that material or in the Appropriate Legal
- Notices displayed by works containing it; or
-- c) Prohibiting misrepresentation of the origin of that material,
- or requiring that modified versions of such material be marked in
- reasonable ways as different from the original version; or
-- d) Limiting the use for publicity purposes of names of licensors
- or authors of the material; or
-- e) Declining to grant rights under trademark law for use of some
- trade names, trademarks, or service marks; or
-- f) Requiring indemnification of licensors and authors of that
- material by anyone who conveys the material (or modified versions
- of it) with contractual assumptions of liability to the recipient,
- for any liability that these contractual assumptions directly
- impose on those licensors and authors.
-
-All other non-permissive additional terms are considered "further
-restrictions" within the meaning of section 10. If the Program as you
-received it, or any part of it, contains a notice stating that it is
-governed by this License along with a term that is a further
-restriction, you may remove that term. If a license document contains
-a further restriction but permits relicensing or conveying under this
-License, you may add to a covered work material governed by the terms
-of that license document, provided that the further restriction does
-not survive such relicensing or conveying.
-
-If you add terms to a covered work in accord with this section, you
-must place, in the relevant source files, a statement of the
-additional terms that apply to those files, or a notice indicating
-where to find the applicable terms.
-
-Additional terms, permissive or non-permissive, may be stated in the
-form of a separately written license, or stated as exceptions; the
-above requirements apply either way.
-
-#### 8. Termination.
-
-You may not propagate or modify a covered work except as expressly
-provided under this License. Any attempt otherwise to propagate or
-modify it is void, and will automatically terminate your rights under
-this License (including any patent licenses granted under the third
-paragraph of section 11).
-
-However, if you cease all violation of this License, then your license
-from a particular copyright holder is reinstated (a) provisionally,
-unless and until the copyright holder explicitly and finally
-terminates your license, and (b) permanently, if the copyright holder
-fails to notify you of the violation by some reasonable means prior to
-60 days after the cessation.
-
-Moreover, your license from a particular copyright holder is
-reinstated permanently if the copyright holder notifies you of the
-violation by some reasonable means, this is the first time you have
-received notice of violation of this License (for any work) from that
-copyright holder, and you cure the violation prior to 30 days after
-your receipt of the notice.
-
-Termination of your rights under this section does not terminate the
-licenses of parties who have received copies or rights from you under
-this License. If your rights have been terminated and not permanently
-reinstated, you do not qualify to receive new licenses for the same
-material under section 10.
-
-#### 9. Acceptance Not Required for Having Copies.
-
-You are not required to accept this License in order to receive or run
-a copy of the Program. Ancillary propagation of a covered work
-occurring solely as a consequence of using peer-to-peer transmission
-to receive a copy likewise does not require acceptance. However,
-nothing other than this License grants you permission to propagate or
-modify any covered work. These actions infringe copyright if you do
-not accept this License. Therefore, by modifying or propagating a
-covered work, you indicate your acceptance of this License to do so.
-
-#### 10. Automatic Licensing of Downstream Recipients.
-
-Each time you convey a covered work, the recipient automatically
-receives a license from the original licensors, to run, modify and
-propagate that work, subject to this License. You are not responsible
-for enforcing compliance by third parties with this License.
-
-An "entity transaction" is a transaction transferring control of an
-organization, or substantially all assets of one, or subdividing an
-organization, or merging organizations. If propagation of a covered
-work results from an entity transaction, each party to that
-transaction who receives a copy of the work also receives whatever
-licenses to the work the party's predecessor in interest had or could
-give under the previous paragraph, plus a right to possession of the
-Corresponding Source of the work from the predecessor in interest, if
-the predecessor has it or can get it with reasonable efforts.
-
-You may not impose any further restrictions on the exercise of the
-rights granted or affirmed under this License. For example, you may
-not impose a license fee, royalty, or other charge for exercise of
-rights granted under this License, and you may not initiate litigation
-(including a cross-claim or counterclaim in a lawsuit) alleging that
-any patent claim is infringed by making, using, selling, offering for
-sale, or importing the Program or any portion of it.
-
-#### 11. Patents.
-
-A "contributor" is a copyright holder who authorizes use under this
-License of the Program or a work on which the Program is based. The
-work thus licensed is called the contributor's "contributor version".
-
-A contributor's "essential patent claims" are all patent claims owned
-or controlled by the contributor, whether already acquired or
-hereafter acquired, that would be infringed by some manner, permitted
-by this License, of making, using, or selling its contributor version,
-but do not include claims that would be infringed only as a
-consequence of further modification of the contributor version. For
-purposes of this definition, "control" includes the right to grant
-patent sublicenses in a manner consistent with the requirements of
-this License.
-
-Each contributor grants you a non-exclusive, worldwide, royalty-free
-patent license under the contributor's essential patent claims, to
-make, use, sell, offer for sale, import and otherwise run, modify and
-propagate the contents of its contributor version.
-
-In the following three paragraphs, a "patent license" is any express
-agreement or commitment, however denominated, not to enforce a patent
-(such as an express permission to practice a patent or covenant not to
-sue for patent infringement). To "grant" such a patent license to a
-party means to make such an agreement or commitment not to enforce a
-patent against the party.
-
-If you convey a covered work, knowingly relying on a patent license,
-and the Corresponding Source of the work is not available for anyone
-to copy, free of charge and under the terms of this License, through a
-publicly available network server or other readily accessible means,
-then you must either (1) cause the Corresponding Source to be so
-available, or (2) arrange to deprive yourself of the benefit of the
-patent license for this particular work, or (3) arrange, in a manner
-consistent with the requirements of this License, to extend the patent
-license to downstream recipients. "Knowingly relying" means you have
-actual knowledge that, but for the patent license, your conveying the
-covered work in a country, or your recipient's use of the covered work
-in a country, would infringe one or more identifiable patents in that
-country that you have reason to believe are valid.
-
-If, pursuant to or in connection with a single transaction or
-arrangement, you convey, or propagate by procuring conveyance of, a
-covered work, and grant a patent license to some of the parties
-receiving the covered work authorizing them to use, propagate, modify
-or convey a specific copy of the covered work, then the patent license
-you grant is automatically extended to all recipients of the covered
-work and works based on it.
-
-A patent license is "discriminatory" if it does not include within the
-scope of its coverage, prohibits the exercise of, or is conditioned on
-the non-exercise of one or more of the rights that are specifically
-granted under this License. You may not convey a covered work if you
-are a party to an arrangement with a third party that is in the
-business of distributing software, under which you make payment to the
-third party based on the extent of your activity of conveying the
-work, and under which the third party grants, to any of the parties
-who would receive the covered work from you, a discriminatory patent
-license (a) in connection with copies of the covered work conveyed by
-you (or copies made from those copies), or (b) primarily for and in
-connection with specific products or compilations that contain the
-covered work, unless you entered into that arrangement, or that patent
-license was granted, prior to 28 March 2007.
-
-Nothing in this License shall be construed as excluding or limiting
-any implied license or other defenses to infringement that may
-otherwise be available to you under applicable patent law.
-
-#### 12. No Surrender of Others' Freedom.
-
-If conditions are imposed on you (whether by court order, agreement or
-otherwise) that contradict the conditions of this License, they do not
-excuse you from the conditions of this License. If you cannot convey a
-covered work so as to satisfy simultaneously your obligations under
-this License and any other pertinent obligations, then as a
-consequence you may not convey it at all. For example, if you agree to
-terms that obligate you to collect a royalty for further conveying
-from those to whom you convey the Program, the only way you could
-satisfy both those terms and this License would be to refrain entirely
-from conveying the Program.
-
-#### 13. Remote Network Interaction; Use with the GNU General Public License.
-
-Notwithstanding any other provision of this License, if you modify the
-Program, your modified version must prominently offer all users
-interacting with it remotely through a computer network (if your
-version supports such interaction) an opportunity to receive the
-Corresponding Source of your version by providing access to the
-Corresponding Source from a network server at no charge, through some
-standard or customary means of facilitating copying of software. This
-Corresponding Source shall include the Corresponding Source for any
-work covered by version 3 of the GNU General Public License that is
-incorporated pursuant to the following paragraph.
-
-Notwithstanding any other provision of this License, you have
-permission to link or combine any covered work with a work licensed
-under version 3 of the GNU General Public License into a single
-combined work, and to convey the resulting work. The terms of this
-License will continue to apply to the part which is the covered work,
-but the work with which it is combined will remain governed by version
-3 of the GNU General Public License.
-
-#### 14. Revised Versions of this License.
-
-The Free Software Foundation may publish revised and/or new versions
-of the GNU Affero General Public License from time to time. Such new
-versions will be similar in spirit to the present version, but may
-differ in detail to address new problems or concerns.
-
-Each version is given a distinguishing version number. If the Program
-specifies that a certain numbered version of the GNU Affero General
-Public License "or any later version" applies to it, you have the
-option of following the terms and conditions either of that numbered
-version or of any later version published by the Free Software
-Foundation. If the Program does not specify a version number of the
-GNU Affero General Public License, you may choose any version ever
-published by the Free Software Foundation.
-
-If the Program specifies that a proxy can decide which future versions
-of the GNU Affero General Public License can be used, that proxy's
-public statement of acceptance of a version permanently authorizes you
-to choose that version for the Program.
-
-Later license versions may give you additional or different
-permissions. However, no additional obligations are imposed on any
-author or copyright holder as a result of your choosing to follow a
-later version.
-
-#### 15. Disclaimer of Warranty.
-
-THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
-APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
-HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT
-WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT
-LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND
-PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE
-DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR
-CORRECTION.
-
-#### 16. Limitation of Liability.
-
-IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
-WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR
-CONVEYS THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
-INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES
-ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT
-NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR
-LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM
-TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER
-PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
-
-#### 17. Interpretation of Sections 15 and 16.
-
-If the disclaimer of warranty and limitation of liability provided
-above cannot be given local legal effect according to their terms,
-reviewing courts shall apply local law that most closely approximates
-an absolute waiver of all civil liability in connection with the
-Program, unless a warranty or assumption of liability accompanies a
-copy of the Program in return for a fee.
-
-END OF TERMS AND CONDITIONS
-
-### How to Apply These Terms to Your New Programs
-
-If you develop a new program, and you want it to be of the greatest
-possible use to the public, the best way to achieve this is to make it
-free software which everyone can redistribute and change under these
-terms.
-
-To do so, attach the following notices to the program. It is safest to
-attach them to the start of each source file to most effectively state
-the exclusion of warranty; and each file should have at least the
-"copyright" line and a pointer to where the full notice is found.
-
-
- Copyright (C)
-
- This program is free software: you can redistribute it and/or modify
- it under the terms of the GNU Affero General Public License as
- published by the Free Software Foundation, either version 3 of the
- License, or (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU Affero General Public License for more details.
-
- You should have received a copy of the GNU Affero General Public License
- along with this program. If not, see .
-
-Also add information on how to contact you by electronic and paper
-mail.
-
-If your software can interact with users remotely through a computer
-network, you should also make sure that it provides a way for users to
-get its source. For example, if your program is a web application, its
-interface could display a "Source" link that leads users to an archive
-of the code. There are many ways you could offer source, and different
-solutions will be better for different programs; see section 13 for
-the specific requirements.
-
-You should also get your employer (if you work as a programmer) or
-school, if any, to sign a "copyright disclaimer" for the program, if
-necessary. For more information on this, and how to apply and follow
-the GNU AGPL, see .
diff --git a/README.md b/README.md
index 31e84212..e2a83eb9 100644
--- a/README.md
+++ b/README.md
@@ -1,46 +1,95 @@
-# PubSolarOS
+[![NixOS](https://img.shields.io/badge/NixOS-unstable-blue.svg?style=flat&logo=NixOS&logoColor=white)](https://nixos.org)
+[![MIT License](https://img.shields.io/github/license/divnix/devos)][mit]
+[![Chat](https://img.shields.io/matrix/devos:nixos.org.svg?label=%23devos%3Anixos.org&logo=matrix&server_fqdn=matrix.org)][matrix]
-Welcome to PubSolarOS, a very opiniated Linux (NixOS) distribution for the nerdy.
+> #### ⚠ Advisory ⚠
+> DevOS requires the [flakes][flakes] feature available via an _experimental_
+> branch of [nix][nix]. Until nix 2.4 is released, this project
+> should be considered unstable.
-We're creating this distribution for our own personal use and fun, but
-take pride in our craft. As of 14.08.22 it's running on 14 physical devices,
-both `x86_64` and `aarch64`.
+### Why?
+Make an awesome template for NixOS users, with consideration for common tools like [home-manager][home-manager],
+[devshell][devshell], and [more](./doc/integrations).
-At its core, it's a NixOS installation running our configuration. The UX
-decisions and the way the project is structured are what make it
-_PubSolarOS_:
+### No. Why _flakes_?
+Flakes are a part of an explicit push to improve [Nix's UX](https://github.com/NixOS/nix/blob/master/doc/manual/src/contributing/cli-guideline.md), and have become an integral part of that effort.
-* Reproducibility is king, and the future is with declarative and functional
- programming. Even if Nix does not turn out to be the end-all-be-all of
- reproducible package management (Guix looks good), it has a plethora
- of packages, a very active and helpful community, and very solid
- software engineering practices.
-* Because reproducibility is king, we're using nix flakes for locking flake
- dependencies. [Digga](https://github.com/divnix/digga) is our flake
- utility library, made by the wonderful people of the Divnix community.
-* Physical devices are not shared anymore nowadays. Only seldomly will you
- find shared devices that need more than one user account. For this
- reason, only one user (excluding `root`) is assumed.
-* Keyboard navigation wins where it matters; ergonomics, programmability,
- efficiency, and speed. We use a tiling window manager (`sway`) and
- prioritize cli-based solutions where sensible. The editor is `neovim`
- configured to be just as opiniated as the operating system it is a part
- of. For mailing, `neomutt` is the default, but we're more divided on
- that part.
-* We like new and shiny things, so we've moved to Wayland and pipewire.
-* SICHERHEIT is written in capital letters at pub.solar, so we have first-
- class disk-encryption support. Currently in the works is a paranoid
- mode where the device can only hibernate (no more sleep or lockscreen)
- so your data is locked any time you leave the device.
-* Free software is better. If we can avoid it, nonfree software is avoided.
- By default, `allowUnfree` is `false` so we don't ship non-free software
- in a basic PubSolarOS ISO. However, nothing prevents you from using
- as much non-free software as you like.
-* Automation is better. The reproducibility of nix feels so much more
- powerful once you're deploying your new configuration from your laptop
- to all your other devices with one command. [We have an automated CI using drone](https://ci.b12f.io/pub-solar/os).
-* Community is important. We just like working on this together, and it
- feels really good to see our progress at the end of a
- [hakken.irl](https://pub.solar/hakken) session.
+They also make [Nix expressions](https://nixos.org/manual/nix/unstable/expressions/expression-syntax.html) easier to distribute and reuse with convient [flake references](https://github.com/NixOS/nix/blob/master/src/nix/flake.md#flake-references) for building or using packages, modules, and whole systems.
-To get started, take a look at the quick start guide in our docs.
+## Getting Started
+Check out the [guide](https://devos.divnix.com/start) to get up and running.
+Also, have a look at [_flake.nix_](./flake.nix). If anything is not immediately
+discoverable via "[`digga`][digga]'s [`mkFlake`][mk-flake],
+please file a bug report.
+
+### Status: Beta
+Although this project has already matured quite a bit, especially through
+recent outfactoring of [`digga`][digga], a fair amount of api polishing is still
+expected. There are unstable versions (0._x_._x_) to help users keep track
+of changes and progress, and a [`develop`](https://github.com/divnix/devos/tree/develop) branch for the brave 😜
+
+## In the Wild
+* @Pacman99: [Personal](https://gitlab.com/coffeetables/lower), [Server](https://gitlab.com/coffeetables/myrdd)
+* [@danielphan2003](https://github.com/danielphan2003/flk) and make sure to also check out [devos-ext-lib][devos-ext-lib]
+* [PubSolarOS](https://git.sr.ht/~b12f/pub-solar-os)
+
+## Shoulders
+This work does not reinvent the wheel. It stands on the [shoulders of the
+following giants][giants]:
+
+### :onion: — like the layers of an onion
+- [`divnix/digga`][digga]
+- [`gytis-ivaskevicius/flake-utils-plus`][fup]
+- [`numtide/flake-utils`][fu]
+
+### :family: — like family
+- [`numtide/devshell`][devshell]
+- [`serokell/deploy-rs`][deploy]
+- [`berberman/nvfetcher`][nvfetcher]
+- [`NixOS/nixpkgs`][nixpkgs]
+
+:heart:
+
+## Inspiration & Art
+- [hlissner/dotfiles][dotfiles]
+- [nix-user-chroot](https://github.com/nix-community/nix-user-chroot)
+- [Nickel](https://github.com/tweag/nickel)
+- [Awesome Nix](https://github.com/nix-community/awesome-nix)
+- [devshell](https://github.com/numtide/devshell)
+
+## Divnix
+The divnix org is an open space that spontaneously formed out of "the Nix".
+It is really just a place where otherwise unrelated people work
+together and get stuff done.
+
+It's a place to stop "geeking out in isolation" (or within company boundaries).
+A place to experiment, learn together, and iterate quickly on best practices.
+That's what it is.
+
+It might eventually become a non-profit if that's not too complicated or, if those
+goals are sufficiently upstreamed into "the Nix", dissolved.
+
+# License
+DevOS is licensed under the [MIT License][mit].
+
+[community]: https://github.com/divnix/devos/tree/community
+[core]: https://github.com/divnix/devos
+[deploy]: https://github.com/serokell/deploy-rs
+[devshell]: https://github.com/numtide/devshell
+[digga]: https://github.com/divnix/digga
+[dotfiles]: https://github.com/hlissner/dotfiles
+[flake-doc]: https://github.com/NixOS/nix/blob/master/src/nix/flake.md
+[flakes]: https://nixos.wiki/wiki/Flakes
+[fu]: https://github.com/numtide/flake-utils
+[fup]: https://github.com/gytis-ivaskevicius/flake-utils-plus
+[giants]: https://en.wikipedia.org/wiki/Standing_on_the_shoulders_of_giants
+[home-manager]: https://nix-community.github.io/home-manager
+[mit]: https://mit-license.org
+[mk-flake]: https://github.com/divnix/digga/tree/main/src/mkFlake
+[nix]: https://nixos.org/manual/nix/stable
+[nixos]: https://nixos.org/manual/nixos/stable
+[nixpkgs]: https://github.com/NixOS/nixpkgs
+[nvfetcher]: https://github.com/berberman/nvfetcher
+[please]: https://github.com/nrdxp/devos/tree/nrd
+[matrix]: https://matrix.to/#/#devos:nixos.org
+[devos-ext-lib]: https://github.com/divnix/devos-ext-lib
diff --git a/doc/CONTRIBUTING.md b/doc/CONTRIBUTING.md
index e3af7e20..86f5dd70 100644
--- a/doc/CONTRIBUTING.md
+++ b/doc/CONTRIBUTING.md
@@ -1,13 +1,18 @@
-# TL;DR;
+# Pull Requests
+
+## TL;DR;
- **Target Branch**: `main`
-- **Merge Policy**: green check: merge away. yellow circle: have patience. red x: try again.
-- **Docs**: every change set is expected to contain doc updates
+- **Merge Policy**: [`bors`][bors] is always right (→ `bors try`)
+- **Docs**: every changeset is expected to contain doc updates
- **Commit Msg**: be a poet! Comprehensive and explanatory commit messages
should cover the motivation and use case in an easily understandable manner
even when read after a few months.
-- **Test Driven Development**: please default to test driven development you can
- make use of the `./examples` & `./e2e` and wire test up in the devshell.
+- **Test Driven Development**: please default to test driven development where possible.
### Within the Devshell (`nix develop`)
- **Hooks**: please `git commit` within the devshell
-- **Fail Early**: please run `check-all` from within the devshell on your local machine
+- **Fail Early**: please run from within the devshell on your local machine:
+ - `nix flake check`
+
+[bors]: https://bors.tech
+
diff --git a/doc/SUMMARY.md b/doc/SUMMARY.md
index 09d2d626..1d7bafe9 100644
--- a/doc/SUMMARY.md
+++ b/doc/SUMMARY.md
@@ -3,6 +3,8 @@
- [Introduction](../README.md)
- [Quick Start](./start/index.md)
- [ISO](./start/iso.md)
+ - [Bootstrapping](./start/bootstrapping.md)
+ - [From NixOS](./start/from-nixos.md)
- [Key Concepts](./concepts/index.md)
- [Hosts](./concepts/hosts.md)
- [Overrides](./concepts/overrides.md)
@@ -16,16 +18,11 @@
- [Concerns]()
- [Secrets](./secrets.md)
- [Tests](./tests.md)
+- [Helper Script – `bud`](./bud/index.md)
+ - [get](./bud/get.md)
- [Integrations](./integrations/index.md)
- [Cachix](./integrations/cachix.md)
- [Deploy RS](./integrations/deploy.md)
- [NvFetcher](./integrations/nvfetcher.md)
- [Hercules CI](./integrations/hercules.md)
-- [API Reference](./api-reference.md)
- - [Channels](./api-reference-channels.md)
- - [Home](./api-reference-home.md)
- - [Devshell](./api-reference-devshell.md)
- - [NixOS](./api-reference-nixos.md)
-- [Library Reference]()
- [Contributing](./CONTRIBUTING.md)
-
diff --git a/doc/api-reference-channels.md b/doc/api-reference-channels.md
deleted file mode 100755
index 533e6e91..00000000
--- a/doc/api-reference-channels.md
+++ /dev/null
@@ -1,91 +0,0 @@
-# Channels API Container
-Configure your channels that you can use throughout your configurations.
-
-> #### ⚠ Gotcha ⚠
-> Devshell & (non-host-specific) Home-Manager `pkgs` instances are rendered off the
-> `nixos.hostDefaults.channelName` (default) channel.
-
-
-## channels
-nixpkgs channels to create
-
-
-*_Type_*:
-attribute set of submodules or path convertible to it
-
-
-*_Default_*
-```
-{}
-```
-
-
-
-
-## channels.\.config
-nixpkgs config for this channel
-
-
-*_Type_*:
-attribute set or path convertible to it
-
-
-*_Default_*
-```
-{}
-```
-
-
-
-
-## channels.\.input
-nixpkgs flake input to use for this channel
-
-
-*_Type_*:
-nix flake
-
-
-*_Default_*
-```
-"self.inputs."
-```
-
-
-
-
-## channels.\.overlays
-overlays to apply to this channel
-these will get exported under the 'overlays' flake output
-as \/\ and any overlay pulled from \
-will be filtered out
-
-
-*_Type_*:
-list of valid Nixpkgs overlay or path convertible to its or anything convertible to it or path convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
-## channels.\.patches
-patches to apply to this channel
-
-
-*_Type_*:
-list of paths
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
diff --git a/doc/api-reference-devshell.md b/doc/api-reference-devshell.md
deleted file mode 100755
index 28f18087..00000000
--- a/doc/api-reference-devshell.md
+++ /dev/null
@@ -1,72 +0,0 @@
-# Devshell API Container
-Configure your devshell module collections of your environment.
-
-
-## devshell
-Modules to include in your DevOS shell. the `modules` argument
-will be exported under the `devshellModules` output
-
-
-*_Type_*:
-submodule or path convertible to it
-
-
-*_Default_*
-```
-{}
-```
-
-
-
-
-## devshell.exportedModules
-modules to include in all hosts and export to devshellModules output
-
-
-*_Type_*:
-list of valid module or path convertible to its or anything convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
-## devshell.externalModules
-The `externalModules` option has been removed.
-Any modules that should be exported should be defined with the `exportedModules`
-option and all other modules should just go into the `modules` option.
-
-
-*_Type_*:
-list of valid modules or anything convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
-## devshell.modules
-modules to include that won't be exported
-meant importing modules from external flakes
-
-
-*_Type_*:
-list of valid modules or anything convertible to it or path convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
diff --git a/doc/api-reference-home.md b/doc/api-reference-home.md
deleted file mode 100755
index 0ab62f36..00000000
--- a/doc/api-reference-home.md
+++ /dev/null
@@ -1,119 +0,0 @@
-# Home-Manager API Container
-Configure your home manager modules, profiles & suites.
-
-
-## home
-hosts, modules, suites, and profiles for home-manager
-
-
-*_Type_*:
-submodule or path convertible to it
-
-
-*_Default_*
-```
-{}
-```
-
-
-
-
-## home.exportedModules
-modules to include in all hosts and export to homeModules output
-
-
-*_Type_*:
-list of valid modules or anything convertible to it or path convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
-## home.externalModules
-The `externalModules` option has been removed.
-Any modules that should be exported should be defined with the `exportedModules`
-option and all other modules should just go into the `modules` option.
-
-
-*_Type_*:
-list of valid modules or anything convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
-## home.importables
-Packages of paths to be passed to modules as `specialArgs`.
-
-
-*_Type_*:
-attribute set
-
-
-*_Default_*
-```
-{}
-```
-
-
-
-
-## home.importables.suites
-collections of profiles
-
-
-*_Type_*:
-null or attribute set of list of paths or anything convertible to its or path convertible to it
-
-
-*_Default_*
-```
-null
-```
-
-
-
-
-## home.modules
-modules to include that won't be exported
-meant importing modules from external flakes
-
-
-*_Type_*:
-list of valid modules or anything convertible to it or path convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
-## home.users
-HM users that can be deployed portably without a host.
-
-
-*_Type_*:
-attribute set of HM user configs
-
-
-*_Default_*
-```
-{}
-```
-
-
-
-
diff --git a/doc/api-reference-nixos.md b/doc/api-reference-nixos.md
deleted file mode 100755
index 7428b161..00000000
--- a/doc/api-reference-nixos.md
+++ /dev/null
@@ -1,234 +0,0 @@
-# NixOS API Container
-Configure your nixos modules, profiles & suites.
-
-
-## nixos
-hosts, modules, suites, and profiles for NixOS
-
-
-*_Type_*:
-submodule or path convertible to it
-
-
-*_Default_*
-```
-{}
-```
-
-
-
-
-## nixos.hostDefaults
-Defaults for all hosts.
-the modules passed under hostDefaults will be exported
-to the 'nixosModules' flake output.
-They will also be added to all hosts.
-
-
-*_Type_*:
-submodule
-
-
-*_Default_*
-```
-{}
-```
-
-
-
-
-## nixos.hostDefaults.channelName
-Channel this host should follow
-
-
-*_Type_*:
-channel defined in `channels`
-
-
-
-
-
-
-## nixos.hostDefaults.exportedModules
-modules to include in all hosts and export to nixosModules output
-
-
-*_Type_*:
-list of valid modules or anything convertible to it or path convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
-## nixos.hostDefaults.externalModules
-The `externalModules` option has been removed.
-Any modules that should be exported should be defined with the `exportedModules`
-option and all other modules should just go into the `modules` option.
-
-
-*_Type_*:
-list of valid modules or anything convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
-## nixos.hostDefaults.modules
-modules to include that won't be exported
-meant importing modules from external flakes
-
-
-*_Type_*:
-list of valid modules or anything convertible to it or path convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
-## nixos.hostDefaults.system
-system for this host
-
-
-*_Type_*:
-null or system defined in `supportedSystems`
-
-
-*_Default_*
-```
-null
-```
-
-
-
-
-## nixos.hosts
-configurations to include in the nixosConfigurations output
-
-
-*_Type_*:
-attribute set of submodules
-
-
-*_Default_*
-```
-{}
-```
-
-
-
-
-## nixos.hosts.\.channelName
-Channel this host should follow
-
-
-*_Type_*:
-null or channel defined in `channels`
-
-
-*_Default_*
-```
-null
-```
-
-
-
-
-## nixos.hosts.\.modules
-modules to include
-
-
-*_Type_*:
-list of valid modules or anything convertible to it or path convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-
-
-## nixos.hosts.\.system
-system for this host
-
-
-*_Type_*:
-null or system defined in `supportedSystems`
-
-
-*_Default_*
-```
-null
-```
-
-
-
-
-## nixos.hosts.\.tests
-tests to run
-
-
-*_Type_*:
-list of valid NixOS test or path convertible to its or anything convertible to it
-
-
-*_Default_*
-```
-[]
-```
-
-
-*_Example_*
-```
-{"_type":"literalExpression","text":"[\n {\n name = \"testname1\";\n machine = { ... };\n testScript = ''\n # ...\n '';\n }\n ({ corutils, writers, ... }: {\n name = \"testname2\";\n machine = { ... };\n testScript = ''\n # ...\n '';\n })\n ./path/to/test.nix\n];\n"}
-```
-
-
-## nixos.importables
-Packages of paths to be passed to modules as `specialArgs`.
-
-
-*_Type_*:
-attribute set
-
-
-*_Default_*
-```
-{}
-```
-
-
-
-
-## nixos.importables.suites
-collections of profiles
-
-
-*_Type_*:
-null or attribute set of list of paths or anything convertible to its or path convertible to it
-
-
-*_Default_*
-```
-null
-```
-
-
-
-
diff --git a/doc/api-reference.md b/doc/api-reference.md
deleted file mode 100755
index 47eb1284..00000000
--- a/doc/api-reference.md
+++ /dev/null
@@ -1,80 +0,0 @@
-# Top Level API
-`digga`'s top level API. API Containers are documented in their respective sub-chapter:
-
-- [Channels](./api-reference-channels.md)
-- [Home](./api-reference-home.md)
-- [Devshell](./api-reference-devshell.md)
-- [NixOS](./api-reference-nixos.md)
-- [Darwin](./api-reference-darwin.md)
-
-## channelsConfig
-nixpkgs config for all channels
-
-
-*_Type_*:
-attribute set or path convertible to it
-
-
-*_Default_*
-```
-{}
-```
-
-
-
-
-## inputs
-The flake's inputs
-
-*_Type_*:
-attribute set of nix flakes
-
-
-
-
-
-
-## outputsBuilder
-builder for flake system-spaced outputs
-The builder gets passed an attrset of all channels
-
-
-*_Type_*:
-function that evaluates to a(n) attribute set or path convertible to it
-
-
-*_Default_*
-```
-"channels: { }"
-```
-
-
-
-
-## self
-The flake to create the DevOS outputs for
-
-*_Type_*:
-nix flake
-
-
-
-
-
-
-## supportedSystems
-The systems supported by this flake
-
-
-*_Type_*:
-list of strings
-
-
-*_Default_*
-```
-["aarch64-linux","aarch64-darwin","i686-linux","x86_64-darwin","x86_64-linux"]
-```
-
-
-
-
diff --git a/doc/bud/get.md b/doc/bud/get.md
new file mode 100644
index 00000000..12263df0
--- /dev/null
+++ b/doc/bud/get.md
@@ -0,0 +1,10 @@
+# get
+The `get` subcommand is useful for getting a bare copy of devos without the
+git history.
+
+## Usage
+```sh
+bud get DEST-DIR
+```
+
+If DEST-DIR is ommitted, it defaults to _./devos_.
diff --git a/doc/bud/index.md b/doc/bud/index.md
new file mode 100644
index 00000000..7b985792
--- /dev/null
+++ b/doc/bud/index.md
@@ -0,0 +1,24 @@
+# [`bud`][bud] command
+The template incudes a convenient script for managing your system called [`bud`][bud].
+
+It is a portable and highly composable system control tool that work anywhere on your host
+or in the flake's devshell.
+
+Although it comes with some predefined standard helpers,
+it is very extensible and you are encouraged to write your own script snippets
+to ease your workflows. An example is the bud module for a `get` command that
+comes included with `devos`.
+
+While writing scripts you can convenientely access smart environment variables
+that can tell the current architecture, user or host name, among others, regardless
+wether you invoke `bud` within the devshell or as the system-wide installed `bud`.
+
+For details, please review the [bud repo][bud].
+
+## Usage
+```sh
+bud help
+```
+
+
+[bud]: https://github.com/divnix/bud
diff --git a/doc/concepts/users.md b/doc/concepts/users.md
index b3454244..b2a6c2a3 100644
--- a/doc/concepts/users.md
+++ b/doc/concepts/users.md
@@ -49,18 +49,19 @@ argument that gets passed to your home-manager users.
## External Usage
You can easily use the defined home-manager configurations outside of NixOS
-using the `homeConfigurations` flake output.
+using the `homeConfigurations` flake output. The [bud](../bud/index.md) helper
+script makes this even easier.
-This is great for keeping your environment consistent across Unix-like systems,
-including macOS.
+This is great for keeping your environment consistent across Unix systems,
+including OSX.
### From within the projects devshell:
```sh
-# builds the pub-solar user defined in the PubSolarOS host
-nix build '.#homeConfigurations."pub-solar@PubSolarOS".activationPackage'
+# builds the nixos user defined in the NixOS host
+bud home NixOS nixos
# build and activate
-nix build '.#homeConfigurations."pub-solar@PubSolarOS".activationPackage' && ./result/activate && unlink result
+bud home NixOS nixos switch
```
### Manually from outside the project:
diff --git a/doc/start/bootstrapping.md b/doc/start/bootstrapping.md
new file mode 100644
index 00000000..b8a0ad04
--- /dev/null
+++ b/doc/start/bootstrapping.md
@@ -0,0 +1,102 @@
+# Bootstrapping
+
+This will help you boostrap a bare host with the help of the
+[bespoke iso](./iso.md) live installer.
+
+_Note: nothing prevents you from remotely executing the boostrapping
+process. See below._
+
+Once your target host has booted into the live iso, you need to partition
+and format your disk according to the [official manual][manual].
+
+## Mount partitions
+
+Then properly mount the formatted partitions at `/mnt`, so that you can
+install your system to those new partitions.
+
+Mount `nixos` partition to `/mnt` and — for UEFI — `boot`
+partition to `/mnt/boot`:
+
+```console
+$ mount /dev/disk/by-label/nixos /mnt
+$ mkdir -p /mnt/boot && mount /dev/disk/by-label/boot /mnt/boot # UEFI only
+$ swapon /dev/disk/by-label/swap
+```
+
+Add some extra space to the store. In the iso, it's running on a tmpfs
+off your RAM:
+```console
+$ mkdir -p /mnt/tmpstore/{work,store}
+$ mount -t overlay overlay -olowerdir=/nix/store,upperdir=/mnt/tmpstore/store,workdir=/mnt/tmpstore/work /nix/store
+```
+
+## Install
+
+Install off of a copy of devos from the time the iso was built:
+
+```console
+$ cd /iso/devos
+$ nixos-install --flake .#NixOS
+```
+
+## Notes of interest
+
+### Remote access to the live installer
+
+The iso live installer comes preconfigured with a network configuration
+which announces it's hostname via [MulticastDNS][mDNS] as `hostname.local`,
+that is `bootstrap.local` in the [iso example](./iso).
+
+In the rare case that [MulticastDNS][mDNS] is not availabe or turned off
+in your network, there is a static link-local IPv6 address configured to
+`fe80::47`(mnemonic from the letter's position in the english alphabet:
+`n=14 i=9 x=24; 47 = n+i+x`).
+
+Provided that you have added your public key to the authorized keys of the
+`root` user _(hint: [`deploy-rs`](../integrations/deploy.md) needs passwordless
+sudo access)_:
+
+```nix
+{ ... }:
+{
+ users.users.root.openssh.authorizedKeys.keyFiles = [
+ ../secrets/path/to/key.pub
+ ];
+}
+```
+
+You can then ssh into the live installer through one of the
+following options:
+
+```console
+ssh root@bootstrap.local
+
+ssh root@fe80::47%eno1 # where eno1 is your network interface on which you are linked to the target
+```
+
+_Note: the [static link-local IPv6 address][staticLLA] and [MulticastDNS][mDNS] is only
+configured on the live installer. If you wish to enable [MulticastDNS][mDNS]
+for your environment, you ought to configure that in a regular [profile](../concepts/profiles.md)._
+
+### EUI-64 LLA & Host Identity
+
+The iso's IPv6 Link Local Address (LLA) is configured with a static 64-bit Extended
+Unique Identifiers (EUI-64) that is derived from the host interface's Message
+Authentication Code (MAC) address.
+
+After a little while (a few seconds), you can remotely discover this unique and host
+specific address over [NDP][NDP] for example with:
+
+```console
+ip -6 neigh show # also shows fe80::47
+```
+
+***This LLA is stable for the host, unless you need to swap that particular network card.***
+Under this reservation, though, you may use this EUI-64 to wire up a specific
+(cryptographic) host identity.
+
+
+[manual]: https://nixos.org/manual/nixos/stable/index.html#sec-installation-partitioning
+[mDNS]: https://en.wikipedia.org/wiki/Multicast_DNS
+[NDP]: https://en.wikipedia.org/wiki/Neighbor_Discovery_Protocol
+[staticLLA]: https://tools.ietf.org/html/rfc7404
diff --git a/doc/start/from-nixos.md b/doc/start/from-nixos.md
new file mode 100644
index 00000000..3e8c84d6
--- /dev/null
+++ b/doc/start/from-nixos.md
@@ -0,0 +1,51 @@
+# From NixOS
+
+## Generate Configuration
+Assuming you're happy with your existing partition layout, you can generate a
+basic NixOS configuration for your system using:
+```sh
+bud up
+```
+
+This will make a new file `hosts/up-$(hostname).nix`, which you can edit to
+your liking.
+
+You must then add a host to `nixos.hosts` in flake.nix:
+```nix
+{
+ nixos.hosts = {
+ modules = hosts/NixOS.nix;
+ };
+}
+```
+
+Make sure your `i18n.defaultLocale` and `time.timeZone` are set properly for
+your region. Keep in mind that `networking.hostName` will be automatically
+set to the name of your host;
+
+Now might be a good time to read the docs on [suites](../concepts/suites.md) and
+[profiles](../concepts/profiles.md) and add or create any that you need.
+
+> ##### _Note:_
+> While the `up` sub-command is provided as a convenience to quickly set up and
+> install a "fresh" NixOS system on current hardware, committing these files is
+> discouraged.
+>
+> They are placed in the git staging area automatically because they would be
+> invisible to the flake otherwise, but it is best to move what you need from
+> them directly into a host module of your own making, and commit that instead.
+# Installation
+
+Once you're ready to deploy `hosts/my-host.nix`:
+```sh
+bud my-host switch
+```
+
+
+This calls `nixos-rebuild` with sudo to build and install your configuration.
+
+> ##### _Notes:_
+> - Instead of `switch`, you can pass `build`, `test`, `boot`, etc just as with
+> `nixos-rebuild`.
+
+
diff --git a/doc/start/index.md b/doc/start/index.md
index 9650ba05..2cd14d9a 100644
--- a/doc/start/index.md
+++ b/doc/start/index.md
@@ -2,35 +2,25 @@
The only dependency is nix, so make sure you have it [installed][install-nix].
## Get the Template
-If you currently don't have flakes setup, you can utilize the digga shell to pull the template:
+Here is a snippet that will get you the template without the git history:
```sh
-nix-shell "https://github.com/divnix/digga/archive/main.tar.gz" \
- --run "nix flake init -t github:divnix/digga"
-```
-If you already have flakes support, you can directly pull the template:
-```sh
-nix flake init -t github:divnix/digga
-```
+nix-shell -p cachix --run "cachix use nrdxp"
+
+nix-shell https://github.com/divnix/devos/archive/main.tar.gz -A shell \
+ --run "bud get main"
+
+cd devos
+
+nix-shell
-Then make sure to create the git repository:
-```sh
git init
git add .
git commit -m init
```
-To drop into a nix-shell, if you don't have flakes setup, use the digga shell to create a `flake.lock`:
-```sh
-nix-shell "https://github.com/divnix/digga/archive/main.tar.gz" \
- --run "nix flake lock"
-```
-Or if you do have flakes support, just run:
-```sh
-nix flake lock
-```
-
-Finally, run `nix-shell` to get to an interactive shell with all the dependencies, including the unstable nix
-version required. You can run `menu` to confirm that you are using digga (expected output includes [docs], [general commands], [linter], etc.).
+This will place you in a new folder named `devos` with git initialized, and a
+nix-shell that provides all the dependencies, including the unstable nix
+version required.
In addition, the [binary cache](../integrations/cachix.md) is added for faster deployment.
@@ -43,8 +33,9 @@ In addition, the [binary cache](../integrations/cachix.md) is added for faster d
> you can try with sudo: `sudo nix-shell -p cachix --run "cachix use nrdxp"`
## Next Steps:
-
- [Make installable ISO](./iso.md)
+- [Bootstrap Host](./bootstrapping.md)
+- [Already on NixOS](./from-nixos.md)
[install-nix]: https://nixos.org/manual/nix/stable/#sect-multi-user-installation
diff --git a/doc/start/iso.md b/doc/start/iso.md
index b8fa6659..76af1c6e 100644
--- a/doc/start/iso.md
+++ b/doc/start/iso.md
@@ -1,36 +1,22 @@
-# Installation Media
-
-This project leverages [nix-community/nixos-generators][nixos-generators] for
-building machine images. In most cases, you'll probably want to use the
-`install-iso` format.
-
-Making an installable ISO for `hosts/bootstrap.nix` is as simple as:
+# ISO
+Making and writing an installable iso for `hosts/bootstrap.nix` is as simple as:
```sh
-nix run github:nix-community/nixos-generators -- \
- --format install-iso \
- --flake '.#bootstrap'
+bud build bootstrap bootstrapIso
+sudo -E $(which bud) burn
```
-Then "burn" the ISO to your USB stick (or CD-R if you like!) following the
-[instructions in the NixOS manual][burn] (or using your preferred USB burner).
+This works for any host.
-You can also swap out the `--format` for [any of the others][formats] supported
-by nixos-generators.
+## ISO image nix store & cache
-Continue by following the usual installation instructions in the NixOS manual.
+The iso image holds the store to the live environment and _also_ acts as a binary cache
+to the installer. To considerably speed up things, the image already includes all flake
+`inputs` as well as the `devshell` closures.
-## ISO Nix Store and Cache
+While you _could_ provision any machine with a single stick, a custom-made iso for
+the host you want to install DevOS to, maximises those local cache hits.
-The ISO image holds the Nix store for the live environment and _also_ acts as a
-binary cache to the installer. To considerably speed things up, the image
-already includes all flake `inputs` as well as the `devshell` closures.
+For hosts that don't differ too much, a single usb stick might be ok, whereas when
+there are bigger differences, a custom-made usb stick will be considerably faster.
-While you _could_ provision any NixOS machine with the same USB stick, an ISO
-custom-made for your target host will maximise those local cache hits. For hosts
-that don't differ too much, a single USB stick might be ok, whereas when there
-are bigger differences, a custom-made USB stick will be considerably faster.
-
-[nixos-generators]: https://github.com/nix-community/nixos-generators
-[burn]: https://nixos.org/manual/nixos/stable/index.html#sec-booting-from-usb
-[formats]: https://github.com/nix-community/nixos-generators/tree/master/formats
diff --git a/flake.lock b/flake.lock
index ba2292ac..e6c7e47d 100644
--- a/flake.lock
+++ b/flake.lock
@@ -7,11 +7,11 @@
]
},
"locked": {
- "lastModified": 1665870395,
- "narHash": "sha256-Tsbqb27LDNxOoPLh0gw2hIb6L/6Ow/6lIBvqcHzEKBI=",
+ "lastModified": 1652712410,
+ "narHash": "sha256-hMJ2TqLt0DleEnQFGUHK9sV2aAzJPU8pZeiZoqRozbE=",
"owner": "ryantm",
"repo": "agenix",
- "rev": "a630400067c6d03c9b3e0455347dc8559db14288",
+ "rev": "7e5e58b98c3dcbf497543ff6f22591552ebfe65b",
"type": "github"
},
"original": {
@@ -20,6 +20,26 @@
"type": "github"
}
},
+ "beautysh": {
+ "inputs": {
+ "flake-utils": "flake-utils",
+ "nixpkgs": "nixpkgs",
+ "poetry2nix": "poetry2nix"
+ },
+ "locked": {
+ "lastModified": 1641830469,
+ "narHash": "sha256-uhDmgNP/biOWe4FtOa6c2xZnREH+NP9rdrMm0LccRUk=",
+ "owner": "lovesegfault",
+ "repo": "beautysh",
+ "rev": "e85d9736927c0fcf2abb05cb3a2d8d9b4502a2eb",
+ "type": "github"
+ },
+ "original": {
+ "owner": "lovesegfault",
+ "repo": "beautysh",
+ "type": "github"
+ }
+ },
"blank": {
"locked": {
"lastModified": 1625557891,
@@ -35,6 +55,31 @@
"type": "github"
}
},
+ "bud": {
+ "inputs": {
+ "beautysh": "beautysh",
+ "devshell": [
+ "digga",
+ "devshell"
+ ],
+ "nixpkgs": [
+ "nixos"
+ ]
+ },
+ "locked": {
+ "lastModified": 1654190822,
+ "narHash": "sha256-B8z3stYaULNDBBjzJHrFHGgiJHrLqhBkxH+9u5iBP7E=",
+ "owner": "divnix",
+ "repo": "bud",
+ "rev": "0ff3e4e4b8791ea4d827bf5bfcac28cef060f209",
+ "type": "github"
+ },
+ "original": {
+ "owner": "divnix",
+ "repo": "bud",
+ "type": "github"
+ }
+ },
"darwin": {
"inputs": {
"nixpkgs": [
@@ -42,11 +87,11 @@
]
},
"locked": {
- "lastModified": 1667294277,
- "narHash": "sha256-YhVGYUpPZNpJZ8z3Sq9aT6n1/B8vKtfRfwaCtbsosxk=",
+ "lastModified": 1657835815,
+ "narHash": "sha256-CnZszAYpNKydh6N7+xg+eRtWNVoAAGqc6bg+Lpgq1xc=",
"owner": "LnL7",
"repo": "nix-darwin",
- "rev": "b7177030643374e698c29e993c2808efa7b85aaf",
+ "rev": "54a24f042f93c79f5679f133faddedec61955cf2",
"type": "github"
},
"original": {
@@ -100,7 +145,7 @@
},
"devshell": {
"inputs": {
- "flake-utils": "flake-utils",
+ "flake-utils": "flake-utils_3",
"nixpkgs": [
"digga",
"nixpkgs"
@@ -143,16 +188,15 @@
"nixpkgs-unstable": "nixpkgs-unstable"
},
"locked": {
- "lastModified": 1661600857,
- "narHash": "sha256-KfQCcTtfvU0PXV4fD9XKIMcKx9lUUR0xWJoBgc12fKE=",
- "owner": "pub-solar",
+ "lastModified": 1659622306,
+ "narHash": "sha256-Kpfm2PNs+kZU0W7qcugoPATLG8I2P7FJFGTgsf1LJiU=",
+ "owner": "divnix",
"repo": "digga",
- "rev": "c902b3ef0aa45cb4f336c390f647bb182c38a221",
+ "rev": "d1193743a535d7fbbc7f3eda4e51295b10bd4d2c",
"type": "github"
},
"original": {
- "owner": "pub-solar",
- "ref": "fix/bootstrap-iso",
+ "owner": "divnix",
"repo": "digga",
"type": "github"
}
@@ -192,11 +236,11 @@
"flake-compat_3": {
"flake": false,
"locked": {
- "lastModified": 1650374568,
- "narHash": "sha256-Z+s0J8/r907g149rllvwhb4pKi8Wam5ij0st8PwAh+E=",
+ "lastModified": 1648199409,
+ "narHash": "sha256-JwPKdC2PoVBkG6E+eWw3j6BMR6sL3COpYWfif7RVb8Y=",
"owner": "edolstra",
"repo": "flake-compat",
- "rev": "b4a34015c698c7793d592d66adbab377907a2be8",
+ "rev": "64a525ee38886ab9028e6f61790de0832aa3ef03",
"type": "github"
},
"original": {
@@ -207,11 +251,11 @@
},
"flake-utils": {
"locked": {
- "lastModified": 1642700792,
- "narHash": "sha256-XqHrk7hFb+zBvRg6Ghl+AZDq03ov6OshJLiSWOoX5es=",
+ "lastModified": 1631561581,
+ "narHash": "sha256-3VQMV5zvxaVLvqqUrNz3iJelLw30mIVSfZmAaauM3dA=",
"owner": "numtide",
"repo": "flake-utils",
- "rev": "846b2ae0fc4cc943637d3d1def4454213e203cba",
+ "rev": "7e5bf3925f6fbdfaf50a2a7ca0be2879c4261d19",
"type": "github"
},
"original": {
@@ -222,7 +266,7 @@
},
"flake-utils-plus": {
"inputs": {
- "flake-utils": "flake-utils_2"
+ "flake-utils": "flake-utils_4"
},
"locked": {
"lastModified": 1654029967,
@@ -240,6 +284,36 @@
}
},
"flake-utils_2": {
+ "locked": {
+ "lastModified": 1649676176,
+ "narHash": "sha256-OWKJratjt2RW151VUlJPRALb7OU2S5s+f0vLj4o1bHM=",
+ "owner": "numtide",
+ "repo": "flake-utils",
+ "rev": "a4b154ebbdc88c8498a5c7b01589addc9e9cb678",
+ "type": "github"
+ },
+ "original": {
+ "owner": "numtide",
+ "repo": "flake-utils",
+ "type": "github"
+ }
+ },
+ "flake-utils_3": {
+ "locked": {
+ "lastModified": 1642700792,
+ "narHash": "sha256-XqHrk7hFb+zBvRg6Ghl+AZDq03ov6OshJLiSWOoX5es=",
+ "owner": "numtide",
+ "repo": "flake-utils",
+ "rev": "846b2ae0fc4cc943637d3d1def4454213e203cba",
+ "type": "github"
+ },
+ "original": {
+ "owner": "numtide",
+ "repo": "flake-utils",
+ "type": "github"
+ }
+ },
+ "flake-utils_4": {
"locked": {
"lastModified": 1644229661,
"narHash": "sha256-1YdnJAsNy69bpcjuoKdOYQX0YxZBiCYZo4Twxerqv7k=",
@@ -254,13 +328,28 @@
"type": "github"
}
},
- "flake-utils_3": {
+ "flake-utils_5": {
"locked": {
- "lastModified": 1659877975,
- "narHash": "sha256-zllb8aq3YO3h8B/U0/J1WBgAL8EX5yWf5pMj3G0NAmc=",
+ "lastModified": 1656928814,
+ "narHash": "sha256-RIFfgBuKz6Hp89yRr7+NR5tzIAbn52h8vT6vXkYjZoM=",
"owner": "numtide",
"repo": "flake-utils",
- "rev": "c0e246b9b83f637f4681389ecabcb2681b4f3af0",
+ "rev": "7e2a3b3dfd9af950a856d66b0a7d01e3c18aa249",
+ "type": "github"
+ },
+ "original": {
+ "owner": "numtide",
+ "repo": "flake-utils",
+ "type": "github"
+ }
+ },
+ "flake-utils_6": {
+ "locked": {
+ "lastModified": 1649676176,
+ "narHash": "sha256-OWKJratjt2RW151VUlJPRALb7OU2S5s+f0vLj4o1bHM=",
+ "owner": "numtide",
+ "repo": "flake-utils",
+ "rev": "a4b154ebbdc88c8498a5c7b01589addc9e9cb678",
"type": "github"
},
"original": {
@@ -276,11 +365,11 @@
]
},
"locked": {
- "lastModified": 1667299227,
- "narHash": "sha256-vAJPFSDYUq3DdCL8OzTg4xObRNW+yA1Pt+NzbhGu1f8=",
+ "lastModified": 1656169755,
+ "narHash": "sha256-Nlnm4jeQWEGjYrE6hxi/7HYHjBSZ/E0RtjCYifnNsWk=",
"owner": "nix-community",
"repo": "home-manager",
- "rev": "f0ecd4b1db5e15103e955b18cb94bea4296e5c45",
+ "rev": "4a3d01fb53f52ac83194081272795aa4612c2381",
"type": "github"
},
"original": {
@@ -308,11 +397,11 @@
},
"latest_2": {
"locked": {
- "lastModified": 1667231093,
- "narHash": "sha256-RERXruzBEBuf0c7OfZeX1hxEKB+PTCUNxWeB6C1jd8Y=",
+ "lastModified": 1660305968,
+ "narHash": "sha256-r0X1pZCSEA6mzt5OuTA7nHuLmvnbkwgpFAh1iLIx4GU=",
"owner": "nixos",
"repo": "nixpkgs",
- "rev": "d40fea9aeb8840fea0d377baa4b38e39b9582458",
+ "rev": "c4a0efdd5a728e20791b8d8d2f26f90ac228ee8d",
"type": "github"
},
"original": {
@@ -322,22 +411,6 @@
"type": "github"
}
},
- "master": {
- "locked": {
- "lastModified": 1667394072,
- "narHash": "sha256-RFTHGjI46hg3ggVwSdssAsni5q5YRsQl2SENv5PPAnQ=",
- "owner": "nixos",
- "repo": "nixpkgs",
- "rev": "07c0c2707bfc78e2b615eb69977ffc6e366c5ec6",
- "type": "github"
- },
- "original": {
- "owner": "nixos",
- "ref": "master",
- "repo": "nixpkgs",
- "type": "github"
- }
- },
"naersk": {
"inputs": {
"nixpkgs": [
@@ -345,11 +418,11 @@
]
},
"locked": {
- "lastModified": 1662220400,
- "narHash": "sha256-9o2OGQqu4xyLZP9K6kNe1pTHnyPz0Wr3raGYnr9AIgY=",
+ "lastModified": 1659610603,
+ "narHash": "sha256-LYgASYSPYo7O71WfeUOaEUzYfzuXm8c8eavJcel+pfI=",
"owner": "nmattia",
"repo": "naersk",
- "rev": "6944160c19cb591eb85bbf9b2f2768a935623ed3",
+ "rev": "c6a45e4277fa58abd524681466d3450f896dc094",
"type": "github"
},
"original": {
@@ -358,6 +431,27 @@
"type": "github"
}
},
+ "nix-dram": {
+ "inputs": {
+ "flake-utils": "flake-utils_5",
+ "nixpkgs": [
+ "latest"
+ ]
+ },
+ "locked": {
+ "lastModified": 1660180791,
+ "narHash": "sha256-oPO+keK4S9daL9ubU51hZ+QOWVSMbZ56F20iFI9Px3s=",
+ "owner": "dramforever",
+ "repo": "nix-dram",
+ "rev": "ae7f0b7c5d39eec5941fe21e9f202106bdea9ac2",
+ "type": "github"
+ },
+ "original": {
+ "owner": "dramforever",
+ "repo": "nix-dram",
+ "type": "github"
+ }
+ },
"nixlib": {
"locked": {
"lastModified": 1636849918,
@@ -375,11 +469,11 @@
},
"nixos": {
"locked": {
- "lastModified": 1667318659,
- "narHash": "sha256-mRXqCdlnxPgm3Wk7mNAOanl7B3Q3U5scYTEiyYmNEOE=",
+ "lastModified": 1660318005,
+ "narHash": "sha256-g9WCa9lVUmOV6dYRbEPjv/TLOR5hamjeCcKExVGS3OQ=",
"owner": "nixos",
"repo": "nixpkgs",
- "rev": "b3a8f7ed267e0a7ed100eb7d716c9137ff120fe3",
+ "rev": "5c211b47aeadcc178c5320afd4e74c7eed5c389f",
"type": "github"
},
"original": {
@@ -392,14 +486,14 @@
"nixos-generators": {
"inputs": {
"nixlib": "nixlib",
- "nixpkgs": "nixpkgs"
+ "nixpkgs": "nixpkgs_3"
},
"locked": {
- "lastModified": 1666812839,
- "narHash": "sha256-0nBDgjPU+iDsvz89W+cDEyhnFGSwCJmwDl/gMGqYiU0=",
+ "lastModified": 1657748715,
+ "narHash": "sha256-WecDwDY/hEcDQYzFnccCNa+5Umht0lfjx/d1qGDy/rQ=",
"owner": "nix-community",
"repo": "nixos-generators",
- "rev": "41f3518bc194389df22a3d198215eae75e6b5ab9",
+ "rev": "3323b944d99b026aebfd8de439e001409dde067d",
"type": "github"
},
"original": {
@@ -410,11 +504,11 @@
},
"nixos-hardware": {
"locked": {
- "lastModified": 1667283320,
- "narHash": "sha256-qHvB/6XBKVjjJJCUM+z6/t9HzUC7J55wdY3KJ/ZWSHo=",
+ "lastModified": 1660291411,
+ "narHash": "sha256-9UfJMJeCl+T/DrOJMd1vLCoV8U3V7f9Qrv/QyH0Nn28=",
"owner": "nixos",
"repo": "nixos-hardware",
- "rev": "18934557eeba8fa2e575b0fd4ab95186e2e3bde3",
+ "rev": "78f56d8ec2c67a1f80f2de649ca9aadc284f65b6",
"type": "github"
},
"original": {
@@ -425,16 +519,16 @@
},
"nixpkgs": {
"locked": {
- "lastModified": 1637186689,
- "narHash": "sha256-NU7BhgnwA/3ibmCeSzFK6xGi+Bari9mPfn+4cBmyEjw=",
+ "lastModified": 1633971123,
+ "narHash": "sha256-WmI4NbH1IPGFWVkuBkKoYgOnxgwSfWDgdZplJlQ93vA=",
"owner": "NixOS",
"repo": "nixpkgs",
- "rev": "7fad01d9d5a3f82081c00fb57918d64145dc904c",
+ "rev": "e4ef597edfd8a0ba5f12362932fc9b1dd01a0aef",
"type": "github"
},
"original": {
"owner": "NixOS",
- "ref": "nixpkgs-unstable",
+ "ref": "nixos-unstable-small",
"repo": "nixpkgs",
"type": "github"
}
@@ -455,6 +549,37 @@
"type": "github"
}
},
+ "nixpkgs_2": {
+ "locked": {
+ "lastModified": 1651340061,
+ "narHash": "sha256-/+4FmvMfUw2IQXiVyMJMNdhf6mEodFRQRHIwUeVEZmk=",
+ "owner": "NixOS",
+ "repo": "nixpkgs",
+ "rev": "d510b23805c37a5b11b86dc3ba8723fcaa6f4539",
+ "type": "github"
+ },
+ "original": {
+ "owner": "NixOS",
+ "repo": "nixpkgs",
+ "type": "github"
+ }
+ },
+ "nixpkgs_3": {
+ "locked": {
+ "lastModified": 1637186689,
+ "narHash": "sha256-NU7BhgnwA/3ibmCeSzFK6xGi+Bari9mPfn+4cBmyEjw=",
+ "owner": "NixOS",
+ "repo": "nixpkgs",
+ "rev": "7fad01d9d5a3f82081c00fb57918d64145dc904c",
+ "type": "github"
+ },
+ "original": {
+ "owner": "NixOS",
+ "ref": "nixpkgs-unstable",
+ "repo": "nixpkgs",
+ "type": "github"
+ }
+ },
"nur": {
"locked": {
"lastModified": 0,
@@ -470,17 +595,17 @@
"nvfetcher": {
"inputs": {
"flake-compat": "flake-compat_3",
- "flake-utils": "flake-utils_3",
+ "flake-utils": "flake-utils_6",
"nixpkgs": [
"nixos"
]
},
"locked": {
- "lastModified": 1667246446,
- "narHash": "sha256-LTnDoH6B8cez7RAc7K/DJqFrnZr75OMtVsNqtIHIPBU=",
+ "lastModified": 1654975372,
+ "narHash": "sha256-wkNZ16akgKViuZzE/IM+bux4uaJ04KIwUeexH8gBjgw=",
"owner": "berberman",
"repo": "nvfetcher",
- "rev": "d5d1289327f26e870991656b2c5598ce62693311",
+ "rev": "d4b237c10f14f72f8266b0f658faad822e491e55",
"type": "github"
},
"original": {
@@ -489,13 +614,32 @@
"type": "github"
}
},
+ "poetry2nix": {
+ "inputs": {
+ "flake-utils": "flake-utils_2",
+ "nixpkgs": "nixpkgs_2"
+ },
+ "locked": {
+ "lastModified": 1633382856,
+ "narHash": "sha256-hYlet806M9xJj4yxf0g5fhDT2IEUVIMAl7sqIeZ8DUM=",
+ "owner": "nix-community",
+ "repo": "poetry2nix",
+ "rev": "705cbfa10e3d9bfed2e59e0256844ae3704dbd7e",
+ "type": "github"
+ },
+ "original": {
+ "owner": "nix-community",
+ "repo": "poetry2nix",
+ "type": "github"
+ }
+ },
"pub-solar": {
"locked": {
- "lastModified": 1654372286,
- "narHash": "sha256-z1WrQkL67Sosz1VnuKQLpzEkEl4ianeLpWJX8Q6bVQY=",
+ "lastModified": 1654369474,
+ "narHash": "sha256-omGF0Ws0l/HE+S08hDObnNptPwM+dVhnA8ya+TAKBHI=",
"owner": "pub-solar",
"repo": "nixpkgs",
- "rev": "4995a873a796c54cc49e5dca9e1d20350eceec7b",
+ "rev": "0b509c42845cea8389e02dcb589eec1c8a165f10",
"type": "github"
},
"original": {
@@ -508,13 +652,14 @@
"root": {
"inputs": {
"agenix": "agenix",
+ "bud": "bud",
"darwin": "darwin",
"deploy": "deploy",
"digga": "digga",
"home": "home",
"latest": "latest_2",
- "master": "master",
"naersk": "naersk",
+ "nix-dram": "nix-dram",
"nixos": "nixos",
"nixos-generators": "nixos-generators",
"nixos-hardware": "nixos-hardware",
diff --git a/flake.nix b/flake.nix
index d4c44813..c67df6f3 100644
--- a/flake.nix
+++ b/flake.nix
@@ -10,15 +10,18 @@
# Track channels with commits tested and built by hydra
nixos.url = "github:nixos/nixpkgs/nixos-22.05";
latest.url = "github:nixos/nixpkgs/nixos-unstable";
- master.url = "github:nixos/nixpkgs/master";
pub-solar.url = "github:pub-solar/nixpkgs/fix/use-latest-unstable-yubikey-agent";
- digga.url = "github:pub-solar/digga/fix/bootstrap-iso";
+ digga.url = "github:divnix/digga";
digga.inputs.nixpkgs.follows = "nixos";
digga.inputs.nixlib.follows = "nixos";
digga.inputs.home-manager.follows = "home";
digga.inputs.deploy.follows = "deploy";
+ bud.url = "github:divnix/bud";
+ bud.inputs.nixpkgs.follows = "nixos";
+ bud.inputs.devshell.follows = "digga/devshell";
+
home.url = "github:nix-community/home-manager/release-22.05";
home.inputs.nixpkgs.follows = "nixos";
@@ -40,11 +43,16 @@
nixos-hardware.url = "github:nixos/nixos-hardware";
nixos-generators.url = "github:nix-community/nixos-generators";
+
+ # PubSolarOS additions
+ nix-dram.url = "github:dramforever/nix-dram";
+ nix-dram.inputs.nixpkgs.follows = "latest";
};
outputs =
{ self
, digga
+ , bud
, nixos
, home
, nixos-hardware
@@ -52,25 +60,27 @@
, agenix
, nvfetcher
, deploy
+ , nix-dram
, ...
} @ inputs:
digga.lib.mkFlake
{
inherit self inputs;
- channelsConfig = {
- allowUnfree = true;
- };
+ channelsConfig = { allowUnfree = true; };
supportedSystems = [ "x86_64-linux" "aarch64-linux" ];
channels = {
nixos = {
imports = [ (digga.lib.importOverlays ./overlays) ];
- overlays = [ ];
+ overlays = [
+ nur.overlay
+ agenix.overlay
+ ./pkgs/default.nix
+ ];
};
latest = { };
- master = { };
};
lib = import ./lib { lib = digga.lib // nixos.lib; };
@@ -82,10 +92,6 @@
our = self.lib;
});
})
- nur.overlay
- agenix.overlay
-
- (import ./pkgs)
];
nixos = {
@@ -95,38 +101,27 @@
imports = [ (digga.lib.importExportableModules ./modules) ];
modules = [
{ lib.our = self.lib; }
- # FIXME: upstream module causes a huge number of unnecessary
- # dependencies to be pulled in for all systems -- many of them are
- # graphical. should only be imported as needed.
- # digga.nixosModules.bootstrapIso
+ digga.nixosModules.bootstrapIso
digga.nixosModules.nixConfig
home.nixosModules.home-manager
agenix.nixosModules.age
+ bud.nixosModules.bud
];
};
imports = [ (digga.lib.importHosts ./hosts) ];
hosts = {
/* set host specific properties here */
- bootstrap = {
- modules = [
- digga.nixosModules.bootstrapIso
- ];
- };
- PubSolarOS = {
- tests = [
- (import ./tests/first-test.nix { pkgs = nixos.legacyPackages.x86_64-linux; lib = nixos.lib; })
- ];
- };
+ PubSolarOS = { };
};
importables = rec {
profiles = digga.lib.rakeLeaves ./profiles // {
users = digga.lib.rakeLeaves ./users;
};
suites = with profiles; rec {
- base = [ users.pub-solar users.root ];
+ base = [ core users.pub-solar users.root ];
iso = base ++ [ base-user graphical pub-solar-iso ];
- pubsolaros = [ full-install base-user users.root ];
+ pubsolaros = [ core full-install base-user users.root ];
anonymous = [ pubsolaros users.pub-solar ];
b12f = pubsolaros ++ [ users.ben social gaming mobile ];
@@ -151,7 +146,6 @@
users = {
pub-solar = { suites, ... }: { imports = suites.base; };
ben = { suites, ... }: { imports = suites.base; };
- yule = { suites, ... }: { imports = suites.base; };
}; # digga.lib.importers.rakeLeaves ./users/hm;
};
@@ -160,9 +154,8 @@
homeConfigurations = digga.lib.mkHomeConfigurations self.nixosConfigurations;
deploy.nodes = digga.lib.mkDeployNodes self.nixosConfigurations {
- droppie = {
- sshUser = "yule";
- };
+ droppie = { };
};
- };
+ }
+ ;
}
diff --git a/hosts/biolimo/biolimo.nix b/hosts/biolimo/biolimo.nix
index b02053d1..820225ea 100644
--- a/hosts/biolimo/biolimo.nix
+++ b/hosts/biolimo/biolimo.nix
@@ -10,27 +10,15 @@ in
];
config = {
- pub-solar.paranoia.enable = true;
- pub-solar.core.hibernation.resumeDevice = "/dev/dm-0";
- pub-solar.core.hibernation.resumeOffset = 15296512;
-
hardware.cpu.intel.updateMicrocode = true;
networking.firewall.allowedTCPPorts = [ 5000 ];
- networking.networkmanager.wifi.backend = mkForce "wpa_supplicant";
-
- home-manager = with pkgs; pkgs.lib.setAttrByPath [ "users" psCfg.user.name ] {
- xdg.configFile = mkIf psCfg.sway.enable {
- "sway/config.d/10-screens.conf".source = ./.config/sway/config.d/screens.conf;
- "sway/config.d/10-autostart.conf".source = ./.config/sway/config.d/autostart.conf;
- "sway/config.d/10-input-defaults.conf".source = ./.config/sway/config.d/input-defaults.conf;
- "sway/config.d/10-custom-keybindings.conf".source = ./.config/sway/config.d/custom-keybindings.conf;
- };
-
- home.packages = [
- inkscape
- ];
+ home-manager.users."${psCfg.user.name}".xdg.configFile = mkIf psCfg.sway.enable {
+ "sway/config.d/10-screens.conf".source = ./.config/sway/config.d/screens.conf;
+ "sway/config.d/10-autostart.conf".source = ./.config/sway/config.d/autostart.conf;
+ "sway/config.d/10-input-defaults.conf".source = ./.config/sway/config.d/input-defaults.conf;
+ "sway/config.d/10-custom-keybindings.conf".source = ./.config/sway/config.d/custom-keybindings.conf;
};
};
}
diff --git a/hosts/bootstrap.nix b/hosts/bootstrap.nix
index 49422675..acadc449 100644
--- a/hosts/bootstrap.nix
+++ b/hosts/bootstrap.nix
@@ -1,22 +1,12 @@
-{ config, lib, pkgs, profiles, ... }:
-with lib;
-let
- # Gets hostname of host to be bundled inside iso
- # Copied from https://github.com/divnix/digga/blob/30ffa0b02272dc56c94fd3c7d8a5a0f07ca197bf/modules/bootstrap-iso.nix#L3-L11
- getFqdn = config:
- let
- net = config.networking;
- fqdn =
- if (net ? domain) && (net.domain != null)
- then "${net.hostName}.${net.domain}"
- else net.hostName;
- in
- fqdn;
-in
+{ profiles, ... }:
{
- # build with: `nix build ".#nixosConfigurations.bootstrap.config.system.build.isoImage"`
+ # build with: `bud build bootstrap bootstrapIso`
+ # reachable on the local link via ssh root@fe80::47%eno1
+ # where 'eno1' is replaced by your own machine's network
+ # interface that has the local link to the target machine
imports = [
# profiles.networking
+ profiles.core
profiles.users.root # make sure to configure ssh keys
profiles.users.pub-solar
profiles.base-user
@@ -24,28 +14,16 @@ in
profiles.pub-solar-iso
];
- config = {
- boot.loader.systemd-boot.enable = true;
+ boot.loader.systemd-boot.enable = true;
- # will be overridden by the bootstrapIso instrumentation
- fileSystems."/" = { device = "/dev/disk/by-label/nixos"; };
+ # will be overridden by the bootstrapIso instrumentation
+ fileSystems."/" = { device = "/dev/disk/by-label/nixos"; };
- system.nixos.label = "PubSolarOS-" + config.system.nixos.version;
-
- # mkForce because a similar transformation gets double applied otherwise
- # https://github.com/divnix/digga/blob/30ffa0b02272dc56c94fd3c7d8a5a0f07ca197bf/modules/bootstrap-iso.nix#L17
- # https://github.com/NixOS/nixpkgs/blob/aecd4d8349b94f9bd5718c74a5b789f233f67326/nixos/modules/installer/cd-dvd/installation-cd-base.nix#L21-L22
- isoImage = {
- isoBaseName = mkForce (getFqdn config);
- isoName = mkForce "${config.system.nixos.label}-${config.isoImage.isoBaseName}-${pkgs.stdenv.hostPlatform.system}.iso";
- };
-
- # This value determines the NixOS release from which the default
- # settings for stateful data, like file locations and database versions
- # on your system were taken. It‘s perfectly fine and recommended to leave
- # this value at the release version of the first install of this system.
- # Before changing this value read the documentation for this option
- # (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
- system.stateVersion = "21.05"; # Did you read the comment?
- };
+ # This value determines the NixOS release from which the default
+ # settings for stateful data, like file locations and database versions
+ # on your system were taken. It‘s perfectly fine and recommended to leave
+ # this value at the release version of the first install of this system.
+ # Before changing this value read the documentation for this option
+ # (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
+ system.stateVersion = "21.05"; # Did you read the comment?
}
diff --git a/hosts/chocolatebar/chocolatebar.nix b/hosts/chocolatebar/chocolatebar.nix
index bb13dce9..eb6efd77 100644
--- a/hosts/chocolatebar/chocolatebar.nix
+++ b/hosts/chocolatebar/chocolatebar.nix
@@ -8,7 +8,6 @@ in
imports = [
./configuration.nix
./virtualisation
- ./factorio
];
config = {
@@ -19,46 +18,30 @@ in
rocm-opencl-runtime
];
- pub-solar.core.hibernation.resumeDevice = "/dev/dm-0";
- pub-solar.core.hibernation.resumeOffset = 115075072;
-
services.openssh.openFirewall = true;
- networking.firewall.allowedTCPPorts = [ 443 ] ++ (if psCfg.sway.vnc.enable then [ 5901 ] else [ ]);
+ networking.firewall.allowedTCPPorts = mkIf psCfg.sway.vnc.enable [ 5901 ];
environment.systemPackages = with pkgs; [
wayvnc
drone-docker-runner
- stdenv.cc.cc.lib
];
age.secrets."vnc-key.pem" = {
file = "${self}/secrets/vnc-key-chocolatebar.pem";
- mode = "400";
+ mode = "700";
owner = psCfg.user.name;
};
age.secrets."vnc-cert.pem" = {
file = "${self}/secrets/vnc-cert-chocolatebar.pem";
- mode = "400";
+ mode = "700";
owner = psCfg.user.name;
};
pub-solar.sway.vnc.enable = true;
- pub-solar.ci-runner.enable = true;
- home-manager.users."${psCfg.user.name}" = {
- xdg.configFile = mkIf psCfg.sway.enable {
- "sway/config.d/10-autostart.conf".source = ./.config/sway/config.d/autostart.conf;
- "sway/config.d/10-input-defaults.conf".source = ./.config/sway/config.d/input-defaults.conf;
- "sway/config.d/10-screens.conf".source = ./.config/sway/config.d/screens.conf;
- };
-
- home.sessionVariables = {
- NIX_CC = "${pkgs.stdenv.cc}";
- };
+ home-manager.users."${psCfg.user.name}".xdg.configFile = mkIf psCfg.sway.enable {
+ "sway/config.d/10-autostart.conf".source = ./.config/sway/config.d/autostart.conf;
+ "sway/config.d/10-input-defaults.conf".source = ./.config/sway/config.d/input-defaults.conf;
+ "sway/config.d/10-screens.conf".source = ./.config/sway/config.d/screens.conf;
};
-
- # For OpenProject development with https
- security.pki.certificates = [
- (builtins.readFile ./step-roots.pem)
- ];
};
}
diff --git a/hosts/chocolatebar/factorio/default.nix b/hosts/chocolatebar/factorio/default.nix
deleted file mode 100644
index 4c818bec..00000000
--- a/hosts/chocolatebar/factorio/default.nix
+++ /dev/null
@@ -1,38 +0,0 @@
-{ config, pkgs, lib, self, ... }:
-with lib;
-let
- psCfg = config.pub-solar;
- xdg = config.home-manager.users."${psCfg.user.name}".xdg;
-
- far-reach = pkgs.stdenv.mkDerivation rec {
- pname = "factorio-far-reach";
- version = "1.1.2";
- src = ./far-reach_1.1.2.zip;
- phases = [ "installPhase" ];
- deps = [ ];
- installPhase = ''
- mkdir -p $out
- cp $src far-reach_1.1.2.zip
- '';
- };
-in
-{
- config = {
- services.factorio = {
- enable = true;
- port = 34197; # The default, but make it explicit
- lan = true;
- admins = [
- "doubtwriter"
- "kattykat"
- ];
- openFirewall = true;
- autosave-interval = 3;
- game-name = "Babes plays v2";
- requireUserVerification = false;
- mods = [
- far-reach
- ];
- };
- };
-}
diff --git a/hosts/chocolatebar/factorio/far-reach_1.1.2.zip b/hosts/chocolatebar/factorio/far-reach_1.1.2.zip
deleted file mode 100644
index 4bae7ec8..00000000
Binary files a/hosts/chocolatebar/factorio/far-reach_1.1.2.zip and /dev/null differ
diff --git a/hosts/chocolatebar/step-roots.pem b/hosts/chocolatebar/step-roots.pem
deleted file mode 100644
index 0e90e42d..00000000
--- a/hosts/chocolatebar/step-roots.pem
+++ /dev/null
@@ -1,13 +0,0 @@
------BEGIN CERTIFICATE-----
-MIIB6DCCAY2gAwIBAgIQD4Q4blCl/ZrTIRU2QpqEOTAKBggqhkjOPQQDAjBSMSMw
-IQYDVQQKExpPcGVuUHJvamVjdCBEZXZlbG9wbWVudCBDQTErMCkGA1UEAxMiT3Bl
-blByb2plY3QgRGV2ZWxvcG1lbnQgQ0EgUm9vdCBDQTAeFw0yMjEwMTgxMTE1NDBa
-Fw0zMjEwMTUxMTE1NDBaMFIxIzAhBgNVBAoTGk9wZW5Qcm9qZWN0IERldmVsb3Bt
-ZW50IENBMSswKQYDVQQDEyJPcGVuUHJvamVjdCBEZXZlbG9wbWVudCBDQSBSb290
-IENBMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEu4rN0lOtgxoC83UKONMy2Ns7
-tI0/u6qPp/Cw92xhaTdh/X9ZWKqIhp2VGj2HUJOOfQXrFew7jbLGOvvoXib0Y6NF
-MEMwDgYDVR0PAQH/BAQDAgEGMBIGA1UdEwEB/wQIMAYBAf8CAQEwHQYDVR0OBBYE
-FPjV1zK2GZu8x4uR0QDotk5kNinEMAoGCCqGSM49BAMCA0kAMEYCIQDS2OpCnHM7
-RV7fFHT3KsG3q4lA3dJUKGighQaQ2qOwNwIhAOMmWGWd3EaD87q4RROyVt3h7vIN
-nMJRu7L9il84hFF2
------END CERTIFICATE-----
diff --git a/hosts/chocolatebar/virtualisation/create-service.nix b/hosts/chocolatebar/virtualisation/create-service.nix
index b88c089b..2f174e99 100644
--- a/hosts/chocolatebar/virtualisation/create-service.nix
+++ b/hosts/chocolatebar/virtualisation/create-service.nix
@@ -15,7 +15,7 @@ in
script =
let
networkXML = pkgs.writeText "network.xml" (import ./network-xml.nix { inherit config; inherit pkgs; inherit lib; });
- machineXML = pkgs.writeText "${vm.name}.xml" (vm.generateXML { inherit config; inherit pkgs; inherit lib; inherit vm; varsFile = varsFile; });
+ machineXML = pkgs.writeText "${vm.name}.xml" (generateXML { inherit config; inherit pkgs; inherit lib; inherit vm; varsFile = varsFile; });
in
''
echo "Checking if ${vm.name} is already running"
@@ -53,10 +53,9 @@ in
${if vm.handOverUSBDevices then ''
# Hand over mouse
- USB_BUS=5
- USB_DEV=$(${pkgs.usbutils}/bin/lsusb | grep 046d:c52b | grep 'Bus 005' | cut -b 18)
+ USB_DEV=$(${pkgs.usbutils}/bin/lsusb | grep 046d:c52b | grep 'Bus 001' | cut -b 18)
LINE_NUMBER=$(cat $TMP_FILE | grep -n -A 1 0xc52b | tail -n 1 | cut -b 1,2,3)
- sed -i "''${LINE_NUMBER}s/.*//" "$TMP_FILE"
+ sed -i "''${LINE_NUMBER}s/\(.\{33\}\)./\1''${USB_DEV}/" "$TMP_FILE"
# Hand over keyboard
USB_BUS=$(${pkgs.usbutils}/bin/lsusb | grep 046d:c328 | cut -b 7)
diff --git a/hosts/chocolatebar/virtualisation/default.nix b/hosts/chocolatebar/virtualisation/default.nix
index 043e3f23..bea0d381 100644
--- a/hosts/chocolatebar/virtualisation/default.nix
+++ b/hosts/chocolatebar/virtualisation/default.nix
@@ -4,11 +4,8 @@ let
psCfg = config.pub-solar;
xdg = config.home-manager.users."${psCfg.user.name}".xdg;
createService = import ./create-service.nix;
- generateXML = import ./guest-xml.nix;
- generateTailsXML = import ./tails-xml.nix;
isolateGPU = "rx550x";
- memory = 48; # in GB
handOverUSBDevices = true;
isolateAnyGPU = isolateGPU != null;
@@ -34,10 +31,8 @@ in
id = "http://microsoft.com/win/10";
gpu = true;
mountHome = false;
- memory = memory;
isolateGPU = isolateGPU;
handOverUSBDevices = handOverUSBDevices;
- generateXML = generateXML;
};
};
vm-manjaro = createService {
@@ -50,27 +45,8 @@ in
id = "https://manjaro.org/download/#i3";
gpu = true;
mountHome = true;
- memory = memory;
isolateGPU = isolateGPU;
handOverUSBDevices = handOverUSBDevices;
- generateXML = generateXML;
- };
- };
- vm-tails = createService {
- inherit config;
- inherit pkgs;
- inherit lib;
- vm = {
- name = "tails";
- disk = "/var/lib/vms/tails/tails-amd64-5.4.iso";
- # disk = "/var/lib/vms/nixos/nixos-minimal.iso";
- id = "https://tails.boum.org/install/index.en.html";
- gpu = false;
- mountHome = false;
- memory = 16;
- isolateGPU = isolateGPU;
- handOverUSBDevices = false;
- generateXML = generateTailsXML;
};
};
};
diff --git a/hosts/chocolatebar/virtualisation/guest-xml.nix b/hosts/chocolatebar/virtualisation/guest-xml.nix
index 876c6714..801e0d77 100644
--- a/hosts/chocolatebar/virtualisation/guest-xml.nix
+++ b/hosts/chocolatebar/virtualisation/guest-xml.nix
@@ -13,8 +13,8 @@ in
- ${toString vm.memory}
- ${toString vm.memory}
+ 33554432
+ 3355443212
@@ -190,7 +190,7 @@ in
@@ -198,7 +198,7 @@ in
diff --git a/hosts/chocolatebar/virtualisation/tails-xml.nix b/hosts/chocolatebar/virtualisation/tails-xml.nix
deleted file mode 100644
index 5efefb22..00000000
--- a/hosts/chocolatebar/virtualisation/tails-xml.nix
+++ /dev/null
@@ -1,183 +0,0 @@
-{ config, pkgs, lib, vm, varsFile, ... }:
-let
- psCfg = config.pub-solar;
- xdg = config.home-manager.users."${psCfg.user.name}".xdg;
- home = config.home-manager.users."${psCfg.user.name}".home;
-in
-''
-
- ${vm.name}
- UUID
-
-
-
-
-
- ${toString vm.memory}
- ${toString vm.memory}
- 8
-
- hvm
-
-
-
-
-
-
-
-
-
-
-
-
-
- destroy
- restart
- destroy
-
-
-
-
-
- /run/libvirt/nix-emulators/qemu-system-x86_64
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- /dev/urandom
-
-
-
- ''
diff --git a/hosts/droppie/configuration.nix b/hosts/droppie/configuration.nix
index bf1d4873..e392cfe5 100644
--- a/hosts/droppie/configuration.nix
+++ b/hosts/droppie/configuration.nix
@@ -2,7 +2,8 @@
# your system. Help is available in the configuration.nix(5) man page
# and in the NixOS manual (accessible by running ‘nixos-help’).
-{ config, pkgs, lib, ... }:
+{ config, pkgs, ... }:
+
{
imports =
[
@@ -10,14 +11,6 @@
./hardware-configuration.nix
];
- boot.loader.systemd-boot.enable = lib.mkForce false;
- boot.loader.grub = {
- enable = true;
- efiSupport = true;
- device = "nodev";
- };
- boot.loader.efi.canTouchEfiVariables = true;
-
# This value determines the NixOS release from which the default
# settings for stateful data, like file locations and database versions
# on your system were taken. It‘s perfectly fine and recommended to leave
diff --git a/hosts/droppie/droppie.nix b/hosts/droppie/droppie.nix
index 4e03b6c2..346f2988 100644
--- a/hosts/droppie/droppie.nix
+++ b/hosts/droppie/droppie.nix
@@ -1,4 +1,4 @@
-{ config, pkgs, lib, self, ... }:
+{ config, pkgs, lib, ... }:
with lib;
let
psCfg = config.pub-solar;
@@ -12,55 +12,6 @@ in
config = {
hardware.cpu.intel.updateMicrocode = true;
- pub-solar.core.disk-encryption-active = false;
- pub-solar.core.lite = true;
-
- security.sudo.extraRules = [
- {
- users = [ "${psCfg.user.name}" ];
- commands = [
- {
- command = "ALL";
- options = [ "NOPASSWD" ];
- }
- ];
- }
- ];
-
- services.openssh.knownHosts = {
- "cloud.pub.solar".publicKey = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIABPJSwr9DfnqV0KoL23BcxlWtRxuOqQpnFnCv4SG/LW";
- };
-
- systemd.services.ssh-tunnel-cloud-pub-solar = {
- unitConfig = {
- Description = "Reverse SSH connection to enable backups from IPv4-only to IPv6-only host";
- After = [ "network.target" ];
- };
- serviceConfig = {
- Type = "simple";
- ExecStart = "${pkgs.openssh}/bin/ssh -vvv -g -N -T -o 'ServerAliveInterval 10' -o 'ExitOnForwardFailure yes' -R 127.0.0.1:22022:localhost:22 root@cloud.pub.solar";
- User = psCfg.user.name;
- Group = "users";
- Restart = "always";
- RestartSec = "5s";
- };
- wantedBy = [ "default.target" ];
- };
-
- services.ddclient = {
- enable = true;
- ipv6 = true;
- domains = [ "backup.b12f.io" ];
- server = "ddns.hosting.de";
- username = "b12f";
- use = "web, web=http://checkip6.spdyn.de/, web-skip=''";
- passwordFile = "/run/agenix/dyndns-droppie.key";
- };
-
- age.secrets."dyndns-droppie.key" = {
- file = "${self}/secrets/dyndns-droppie.key";
- mode = "400";
- owner = "root";
- };
+ pub-solar.x-os.disk-encryption-active = false;
};
}
diff --git a/hosts/droppie/hardware-configuration.nix b/hosts/droppie/hardware-configuration.nix
index 3c63750d..9c1fa078 100644
--- a/hosts/droppie/hardware-configuration.nix
+++ b/hosts/droppie/hardware-configuration.nix
@@ -47,7 +47,6 @@
# with explicit per-interface declarations with `networking.interfaces..useDHCP`.
networking.useDHCP = lib.mkDefault true;
networking.interfaces.enp2s0f0.useDHCP = lib.mkDefault true;
- networking.interfaces.enp2s0f1.useDHCP = lib.mkDefault true;
powerManagement.cpuFreqGovernor = lib.mkDefault "ondemand";
hardware.cpu.amd.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
diff --git a/modules/ci-runner/default.nix b/modules/ci-runner/default.nix
deleted file mode 100644
index 1460ab16..00000000
--- a/modules/ci-runner/default.nix
+++ /dev/null
@@ -1,41 +0,0 @@
-{ lib, config, pkgs, self, ... }:
-with lib;
-let
- psCfg = config.pub-solar;
- cfg = config.pub-solar.ci-runner;
-in
-{
- options.pub-solar.ci-runner = {
- enable = mkEnableOption "Enables a systemd service that runs drone-ci-runner";
- };
-
- config = mkIf cfg.enable {
- systemd.user.services.ci-runner = {
- enable = true;
-
- description = "CI runner for the PubSolarOS repository that can run test VM instances with KVM.";
-
- serviceConfig = {
- Type = "simple";
- Restart = "always";
- };
-
- path = [
- pkgs.git
- pkgs.nix
- pkgs.libvirt
- ];
-
- wantedBy = [ "multi-user.target" ];
- after = [ "network.target" "libvirtd.service" ];
-
- script = ''${pkgs.drone-runner-exec}/bin/drone-runner-exec daemon /run/agenix/drone-runner-exec-config'';
- };
-
- age.secrets."drone-runner-exec-config" = {
- file = "${self}/secrets/drone-runner-exec-config";
- mode = "700";
- owner = psCfg.user.name;
- };
- };
-}
diff --git a/modules/core/boot.nix b/modules/core/boot.nix
deleted file mode 100644
index 0d631251..00000000
--- a/modules/core/boot.nix
+++ /dev/null
@@ -1,42 +0,0 @@
-{ config, pkgs, lib, ... }:
-let
- cfg = config.pub-solar.core;
-in
-with lib;
-{
- options.pub-solar.core.iso-options.enable = mkOption {
- type = types.bool;
- default = false;
- description = "Feature flag for iso builds";
- };
-
- options.pub-solar.core.disk-encryption-active = mkOption {
- type = types.bool;
- default = true;
- description = "Whether it should be assumed that there is a cryptroot device";
- };
-
- config = {
- boot = {
- # Enable plymouth for better experience of booting
- plymouth.enable = mkIf (!cfg.lite) (lib.mkDefault true);
-
- # Mount / luks device in initrd
- # Allow fstrim to work on it.
- # The ! makes this enabled by default
- initrd = mkIf (!cfg.iso-options.enable && cfg.disk-encryption-active) {
- luks.devices."cryptroot" = {
- allowDiscards = true;
- };
- };
-
- loader.systemd-boot.enable = true;
-
- # Use latest LTS linux kernel by default
- kernelPackages = pkgs.linuxPackages_5_15;
-
- # Support ntfs drives
- supportedFilesystems = [ "ntfs" ];
- };
- };
-}
diff --git a/modules/core/default.nix b/modules/core/default.nix
deleted file mode 100644
index 4f74b46d..00000000
--- a/modules/core/default.nix
+++ /dev/null
@@ -1,41 +0,0 @@
-{ config, lib, ... }:
-
-with lib;
-let
- cfg = config.pub-solar.core;
-in
-{
- imports = [
- ./boot.nix
- ./hibernation.nix
- ./fonts.nix
- ./i18n.nix
- ./networking.nix
- ./nix.nix
- ./packages.nix
- ./services.nix
- ];
-
- options.pub-solar.core = {
- lite = mkOption {
- description = ''
- Enable a lite edition of core with less default modules and a reduced package set.
- '';
- default = false;
- type = types.bool;
- };
- };
-
- config = {
- pub-solar = {
- audio.enable = mkIf (!cfg.lite) (mkDefault true);
- crypto.enable = mkIf (!cfg.lite) (mkDefault true);
- devops.enable = mkIf (!cfg.lite) (mkDefault true);
-
- terminal-life = {
- enable = mkDefault true;
- lite = cfg.lite;
- };
- };
- };
-}
diff --git a/modules/core/fonts.nix b/modules/core/fonts.nix
deleted file mode 100644
index 979ffc68..00000000
--- a/modules/core/fonts.nix
+++ /dev/null
@@ -1,12 +0,0 @@
-{ config, pkgs, lib, ... }:
-
-{
- fonts = {
- fonts = with pkgs; [ powerline-fonts dejavu_fonts ];
- fontconfig.defaultFonts = {
- monospace = [ "DejaVu Sans Mono for Powerline" ];
- sansSerif = [ "DejaVu Sans" ];
- };
- };
-}
-
diff --git a/modules/core/hibernation.nix b/modules/core/hibernation.nix
deleted file mode 100644
index a71ffd37..00000000
--- a/modules/core/hibernation.nix
+++ /dev/null
@@ -1,33 +0,0 @@
-{ config, pkgs, lib, ... }:
-with lib;
-let
- cfg = config.pub-solar.core.hibernation;
-in
-{
- options.pub-solar.core.hibernation = {
- enable = mkOption {
- type = types.bool;
- default = false;
- description = "Whether the device can hibernate. This creates a swapfile at /swapfile.";
- };
-
- resumeDevice = mkOption {
- type = types.str;
- default = "/dev/sda1";
- description = "The location of the hibernation resume swap file.";
- };
-
- resumeOffset = mkOption {
- type = types.nullOr types.int;
- default = null;
- description = "The swap file offset. Can be found by running `filefrag -v $swap_file_location`. See https://wiki.archlinux.org/title/Power_management/Suspend_and_hibernate#Hibernation_into_swap_file";
- };
- };
-
- config = {
- boot = mkIf cfg.enable {
- resumeDevice = cfg.resumeDevice;
- kernelParams = mkIf (cfg.resumeOffset != null) [ "resume_offset=${builtins.toString cfg.resumeOffset}" ];
- };
- };
-}
diff --git a/modules/core/networking.nix b/modules/core/networking.nix
deleted file mode 100644
index c5ec9cbe..00000000
--- a/modules/core/networking.nix
+++ /dev/null
@@ -1,81 +0,0 @@
-{ config, pkgs, lib, ... }:
-
-with lib;
-
-let cfg = config.pub-solar.core;
-in
-{
- options.pub-solar.core = {
- enableCaddy = mkOption {
- type = types.bool;
- default = !cfg.lite;
- };
- enableHelp = mkOption {
- type = types.bool;
- default = !cfg.lite;
- };
-
- binaryCaches = mkOption {
- type = types.listOf types.str;
- default = [ ];
- description = "Binary caches to use.";
- };
- publicKeys = mkOption {
- type = types.listOf types.str;
- default = [ ];
- description = "Public keys of binary caches.";
- };
- };
- config = {
- # disable NetworkManager-wait-online by default
- systemd.services.NetworkManager-wait-online.enable = lib.mkDefault false;
-
- networking.networkmanager = {
- # Enable networkmanager. REMEMBER to add yourself to group in order to use nm related stuff.
- enable = true;
- wifi.backend = "iwd";
- };
-
- networking.firewall.enable = true;
-
- # Customized binary caches list (with fallback to official binary cache)
- nix.binaryCaches = cfg.binaryCaches;
- nix.binaryCachePublicKeys = cfg.publicKeys;
-
- # These entries get added to /etc/hosts
- networking.hosts = {
- "127.0.0.1" = [ ]
- ++ lib.optionals cfg.enableCaddy [ "caddy.local" ]
- ++ lib.optionals config.pub-solar.printing.enable [ "cups.local" ]
- ++ lib.optionals cfg.enableHelp [ "help.local" ];
- };
-
- # Caddy reverse proxy for local services like cups
- services.caddy = {
- enable = cfg.enableCaddy;
- globalConfig = ''
- default_bind 127.0.0.1
- auto_https off
- '';
- extraConfig = concatStringsSep "\n" [
- (lib.optionalString
- config.pub-solar.printing.enable
- ''
- cups.local:80 {
- request_header Host localhost:631
- reverse_proxy unix//run/cups/cups.sock
- }
- '')
-
- (lib.optionalString
- cfg.enableHelp
- ''
- help.local:80 {
- root * ${pkgs.psos-docs}/lib/html
- file_server
- }
- '')
- ];
- };
- };
-}
diff --git a/modules/core/nix.nix b/modules/core/nix.nix
deleted file mode 100644
index f7ff5fa4..00000000
--- a/modules/core/nix.nix
+++ /dev/null
@@ -1,25 +0,0 @@
-{ config, pkgs, lib, inputs, ... }:
-
-{
- nix = {
- # Use default version alias for nix package
- package = pkgs.nix;
- # Improve nix store disk usage
- autoOptimiseStore = true;
- gc.automatic = true;
- optimise.automatic = true;
- # Prevents impurities in builds
- useSandbox = true;
- # give root and @wheel special privileges with nix
- trustedUsers = [ "root" "@wheel" ];
- # This is just a representation of the nix default
- systemFeatures = [ "nixos-test" "benchmark" "big-parallel" "kvm" ];
- # Generally useful nix option defaults
- extraOptions = ''
- min-free = 536870912
- keep-outputs = true
- keep-derivations = true
- fallback = true
- '';
- };
-}
diff --git a/modules/core/packages.nix b/modules/core/packages.nix
deleted file mode 100644
index f6867816..00000000
--- a/modules/core/packages.nix
+++ /dev/null
@@ -1,75 +0,0 @@
-{ config, pkgs, lib, ... }:
-
-with lib;
-let
- psCfg = config.pub-solar;
- cfg = config.pub-solar.core;
-in
-{
- environment = {
- systemPackages = with pkgs; [
- # Core unix utility packages
- coreutils-full
- dnsutils
- inetutils
- progress
- pciutils
- usbutils
-
- wget
- openssl
- openssh
- curl
- htop
- lsof
- psmisc
- file
-
- # zippit
- zip
- unzip
-
- # Modern modern utilities
- p7zip
- croc
- jq
- ]
-
- ++ lib.optionals (!cfg.lite) [
- mtr
-
- gitFull
- git-lfs
- git-bug
-
- xdg-utils
- sysfsutils
- renameutils
- nfs-utils
- moreutils
- mailutils
- keyutils
- input-utils
- elfutils
- binutils
- dateutils
- diffutils
- findutils
- exfat
-
- # Nix specific utilities
- niv
- manix
- nix-index
- nix-tree
- nixpkgs-review
- # Build broken, python2.7-PyJWT-2.0.1.drv' failed
- #nixops
- psos
- nvd
-
- # Fun
- neofetch
- ];
- };
-}
diff --git a/modules/core/services.nix b/modules/core/services.nix
deleted file mode 100644
index 6ce74472..00000000
--- a/modules/core/services.nix
+++ /dev/null
@@ -1,15 +0,0 @@
-{ config, pkgs, lib, ... }:
-
-{
- # For rage encryption, all hosts need a ssh key pair
- services.openssh = {
- enable = true;
- # If you don't want the host to have SSH actually opened up to the net,
- # set `services.openssh.openFirewall` to false in your config.
- openFirewall = lib.mkDefault true;
- passwordAuthentication = false;
- };
-
- # Service that makes Out of Memory Killer more effective
- services.earlyoom.enable = true;
-}
diff --git a/modules/graphical/alacritty.nix b/modules/graphical/alacritty.nix
index b389343c..e4e2f6ad 100644
--- a/modules/graphical/alacritty.nix
+++ b/modules/graphical/alacritty.nix
@@ -100,15 +100,10 @@
foreground = "0xe3e1e4";
};
- # Cursor colors
- #
- # Colors which should be used to draw the terminal cursor.
- #
- # Allowed values are CellForeground/CellBackground, which reference the
- # affected cell, or hexadecimal colors like #ff00ff.
+ # Colors the cursor will use if `custom_cursor_colors` is true
cursor = {
- text = "CellBackground";
- cursor = "CellForeground";
+ text = "0x1a181a";
+ cursor = "0xe3e1e4";
};
# Colors used for the search bar and match highlighting.
@@ -120,25 +115,14 @@
background = "0x1a181a";
};
focused_match = {
- foreground = "CellBackground";
- background = "CellForeground";
+ foreground = "0xe5c463";
+ background = "0xe3e1e4";
};
#bar =
# background = "#c5c8c6";
# foreground = "#1d1f21";
};
- # Selection colors
- #
- # Colors which should be used to draw the selection area.
- #
- # Allowed values are CellForeground/CellBackground, which reference the
- # affected cell, or hexadecimal colors like #ff00ff.
- selection = {
- text = "0x1a181a";
- background = "0xf85e84";
- };
-
# Normal colors
normal = {
black = "0x1a181a";
diff --git a/modules/graphical/default.nix b/modules/graphical/default.nix
index ede262b3..0bb9781c 100644
--- a/modules/graphical/default.nix
+++ b/modules/graphical/default.nix
@@ -5,19 +5,17 @@ let
cfg = config.pub-solar.graphical;
yamlFormat = pkgs.formats.yaml { };
recursiveMerge = attrList:
- let
- f = attrPath:
- zipAttrsWith (n: values:
- if tail values == [ ]
- then head values
- else if all isList values
- then unique (concatLists values)
- else if all isAttrs values
- then f (attrPath ++ [ n ]) values
- else last values
- );
- in
- f [ ] attrList;
+ let f = attrPath:
+ zipAttrsWith (n: values:
+ if tail values == [ ]
+ then head values
+ else if all isList values
+ then unique (concatLists values)
+ else if all isAttrs values
+ then f (attrPath ++ [ n ]) values
+ else last values
+ );
+ in f [ ] attrList;
in
{
options.pub-solar.graphical = {
@@ -61,7 +59,7 @@ in
};
};
- services.getty.autologinUser = mkIf cfg.autologin.enable (mkForce "${psCfg.user.name}");
+ services.getty.autologinUser = mkIf cfg.autologin.enable "${psCfg.user.name}";
qt5 = {
enable = true;
@@ -79,6 +77,7 @@ in
fonts.enableDefaultFonts = true;
fonts.fonts = with pkgs; [
+ corefonts
fira-code
fira-code-symbols
google-fonts
diff --git a/modules/paranoia/default.nix b/modules/paranoia/default.nix
deleted file mode 100644
index 202d9f5a..00000000
--- a/modules/paranoia/default.nix
+++ /dev/null
@@ -1,56 +0,0 @@
-{ config, lib, ... }:
-
-with lib;
-let
- psCfg = config.pub-solar;
- cfg = config.pub-solar.paranoia;
-in
-{
- options.pub-solar.paranoia = {
- enable = mkOption {
- description = ''
- Only offer hibernation instead of screen locking and sleeping. This only makes sense
- if your hard drive is encrypted, and ensures that the contents of your drive are
- encrypted if you are not actively using the device.
- '';
- default = false;
- type = types.bool;
- };
- };
-
- config = mkIf cfg.enable {
- pub-solar.core.hibernation.enable = true;
- services.logind.lidSwitch = "hibernate";
-
- services.tor.settings = {
- UseBridges = true;
- };
-
- # The options below are directly taken from or inspired by
- # https://xeiaso.net/blog/paranoid-nixos-2021-07-18
-
- # Don't set this if you need sftp
- services.openssh.allowSFTP = false;
- services.openssh.openFirewall = false; # Lock yourself out
-
- # Limit the use of sudo to the group wheel
- security.sudo.execWheelOnly = true;
-
- # Remove the complete default environment of packages like
- # nano, perl and rsync
- environment.defaultPackages = lib.mkForce [ ];
-
- # fileSystems."/".options = [ "noexec" ];
-
- services.openssh = {
- kbdInteractiveAuthentication = false;
- extraConfig = ''
- AllowTcpForwarding yes
- X11Forwarding no
- AllowAgentForwarding no
- AllowStreamLocalForwarding no
- AuthenticationMethods publickey
- '';
- };
- };
-}
diff --git a/modules/printing/default.nix b/modules/printing/default.nix
index 1e8fa9de..48a6c3c4 100644
--- a/modules/printing/default.nix
+++ b/modules/printing/default.nix
@@ -21,6 +21,10 @@ in
services.printing.defaultShared = false;
services.printing.drivers = [
pkgs.gutenprint
+ pkgs.brgenml1lpr
+ pkgs.brgenml1cupswrapper
+ pkgs.brlaser
+ pkgs.cups-brother-hl3140cw
];
hardware.sane = {
enable = true;
diff --git a/modules/sway/config/config.d/custom-keybindings.conf b/modules/sway/config/config.d/custom-keybindings.conf
index 4c7f0614..f86cf0be 100644
--- a/modules/sway/config/config.d/custom-keybindings.conf
+++ b/modules/sway/config/config.d/custom-keybindings.conf
@@ -37,6 +37,22 @@ bindsym $mod+Ctrl+r exec record-screen
set $menu exec alacritty --class launcher -e env TERMINAL_COMMAND="alacritty -e" sway-launcher
bindsym $mod+Space exec $menu
+# Set shut down, restart and locking features
+set $mode_system (l)ock, (e)xit, (s)uspend, (h)ibernate, (r)eboot, (Shift+s)hutdown
+bindsym $mod+0 mode "$mode_system"
+mode "$mode_system" {
+ bindsym l exec swaylock-bg, mode "default"
+ bindsym e exec systemctl --user stop graphical-session.target, mode "default"
+ bindsym s exec systemctl suspend, mode "default"
+ bindsym h exec systemctl hibernate, mode "default"
+ bindsym r exec systemctl reboot, mode "default"
+ bindsym Shift+s exec systemctl poweroff, mode "default"
+
+ # exit system mode: "Enter" or "Escape"
+ bindsym Return mode "default"
+ bindsym Escape mode "default"
+}
+
set $mode_vncclient In VNCClient mode. Press $mod+Num_Lock or $mod+Shift+Escape to return.
bindsym $mod+Num_Lock mode "$mode_vncclient"
bindsym $mod+Shift+Escape mode "$mode_vncclient"
diff --git a/modules/sway/config/config.d/mode_system.conf.nix b/modules/sway/config/config.d/mode_system.conf.nix
deleted file mode 100644
index f01921c4..00000000
--- a/modules/sway/config/config.d/mode_system.conf.nix
+++ /dev/null
@@ -1,28 +0,0 @@
-{ pkgs, psCfg, ... }: ''
- # Set shut down, restart and locking features
-'' + (if psCfg.core.hibernation.enable && !psCfg.paranoia.enable then ''
- set $mode_system (e)xit, (h)ibernate, (l)ock, (s)uspend, (r)eboot, (Shift+s)hutdown
-'' else if psCfg.paranoia.enable then ''
- set $mode_system (e)xit, (h)ibernate, (r)eboot, (Shift+s)hutdown
-'' else ''
- set $mode_system (e)xit, (l)ock, (s)uspend, (r)eboot, (Shift+s)hutdown
-'')
-+ ''
- bindsym $mod+0 mode "$mode_system"
- mode "$mode_system" {
- bindsym e exec swaymsg exit, mode "default"
-'' + (if psCfg.core.hibernation.enable then ''
- bindsym h exec systemctl hibernate, mode "default"
-'' else "")
-+ (if !psCfg.paranoia.enable then ''
- bindsym l exec ${pkgs.swaylock-bg}/bin/swaylock-bg, mode "default"
- bindsym s exec systemctl suspend, mode "default"
-'' else "") + ''
- bindsym r exec systemctl reboot, mode "default"
- bindsym Shift+s exec systemctl poweroff, mode "default"
-
- # exit system mode: "Enter" or "Escape"
- bindsym Return mode "default"
- bindsym Escape mode "default"
- }
-''
diff --git a/modules/sway/config/config.d/systemd.conf b/modules/sway/config/config.d/systemd.conf
index 66759c4f..d6380d41 100644
--- a/modules/sway/config/config.d/systemd.conf
+++ b/modules/sway/config/config.d/systemd.conf
@@ -5,4 +5,4 @@
# https://github.com/swaywm/sway/wiki/Systemd-integration
# Also, import the most important environment variables into the D-Bus and systemd
# user environments (e.g. required for screen sharing and Pinentry prompts):
-exec "systemctl --user import-environment; systemctl --user start sway-session.target; exec dbus-update-activation-environment --systemd $IMPORT_ENVIRONMENT_ENV_LIST DISPLAY WAYLAND_DISPLAY SWAYSOCK XDG_CURRENT_DESKTOP; systemd-cat --identifier=sway sway"
+exec "systemctl --user import-environment DISPLAY WAYLAND_DISPLAY SWAYSOCK XDG_CURRENT_DESKTOP; systemctl --user start sway-session.target; exec dbus-update-activation-environment --systemd DISPLAY WAYLAND_DISPLAY SWAYSOCK XDG_CURRENT_DESKTOP; systemd-cat --identifier=sway sway"
diff --git a/modules/sway/default.nix b/modules/sway/default.nix
index e6c43b14..f15aabc5 100644
--- a/modules/sway/default.nix
+++ b/modules/sway/default.nix
@@ -2,6 +2,7 @@
with lib;
let
psCfg = config.pub-solar;
+ cfg = config.pub-solar.sway;
in
{
options.pub-solar.sway = {
@@ -22,8 +23,8 @@ in
};
};
- config = mkIf psCfg.sway.enable (mkMerge [
- (mkIf (psCfg.sway.v4l2loopback.enable) {
+ config = mkIf cfg.enable (mkMerge [
+ (mkIf (cfg.v4l2loopback.enable) {
boot.extraModulePackages = with config.boot.kernelPackages; [ v4l2loopback ];
boot.kernelModules = [ "v4l2loopback" ];
boot.extraModprobeConfig = ''
@@ -78,6 +79,7 @@ in
xsettingsd
ydotool
+ swaylock-bg
sway-launcher
record-screen
import-gtk-settings
@@ -88,21 +90,20 @@ in
programs.waybar.enable = true;
#programs.waybar.systemd.enable = true;
- systemd.user.services.mako = import ./mako.service.nix { inherit pkgs psCfg; };
- systemd.user.services.sway = import ./sway.service.nix { inherit pkgs psCfg; };
- systemd.user.services.swayidle = import ./swayidle.service.nix { inherit pkgs psCfg; };
- systemd.user.services.xsettingsd = import ./xsettingsd.service.nix { inherit pkgs psCfg; };
- systemd.user.services.waybar = import ./waybar.service.nix { inherit pkgs psCfg; };
- systemd.user.targets.sway-session = import ./sway-session.target.nix { inherit pkgs psCfg; };
+ systemd.user.services.mako = import ./mako.service.nix pkgs;
+ systemd.user.services.sway = import ./sway.service.nix pkgs;
+ systemd.user.services.swayidle = import ./swayidle.service.nix pkgs;
+ systemd.user.services.xsettingsd = import ./xsettingsd.service.nix pkgs;
+ systemd.user.services.waybar = import ./waybar.service.nix pkgs;
+ systemd.user.targets.sway-session = import ./sway-session.target.nix pkgs;
- systemd.user.services.wayvnc = mkIf psCfg.sway.vnc.enable (import ./wayvnc.service.nix pkgs);
+ systemd.user.services.wayvnc = mkIf cfg.vnc.enable (import ./wayvnc.service.nix pkgs);
xdg.configFile."sway/config".text = import ./config/config.nix { inherit config pkgs; };
xdg.configFile."sway/config.d/colorscheme.conf".source = ./config/config.d/colorscheme.conf;
xdg.configFile."sway/config.d/theme.conf".source = ./config/config.d/theme.conf;
xdg.configFile."sway/config.d/gaps.conf".source = ./config/config.d/gaps.conf;
xdg.configFile."sway/config.d/custom-keybindings.conf".source = ./config/config.d/custom-keybindings.conf;
- xdg.configFile."sway/config.d/mode_system.conf".text = import ./config/config.d/mode_system.conf.nix { inherit pkgs psCfg; };
xdg.configFile."sway/config.d/applications.conf".source = ./config/config.d/applications.conf;
xdg.configFile."sway/config.d/systemd.conf".source = ./config/config.d/systemd.conf;
xdg.configFile."wayvnc/config".text = import ./config/wayvnc/config.nix { inherit psCfg; inherit pkgs; };
diff --git a/modules/sway/gammastep.service.nix b/modules/sway/gammastep.service.nix
index 3960d1ae..f59edf02 100644
--- a/modules/sway/gammastep.service.nix
+++ b/modules/sway/gammastep.service.nix
@@ -1,4 +1,4 @@
-{ pkgs, ... }:
+pkgs:
{
Unit = {
Description = "set color temperature of display according to time of day";
diff --git a/modules/sway/libinput-gestures.service.nix b/modules/sway/libinput-gestures.service.nix
index 798d10d6..c4c860da 100644
--- a/modules/sway/libinput-gestures.service.nix
+++ b/modules/sway/libinput-gestures.service.nix
@@ -1,4 +1,4 @@
-{ pkgs, ... }:
+pkgs:
{
Unit = {
Description = "Actions gestures on your touchpad using libinput";
diff --git a/modules/sway/mako.service.nix b/modules/sway/mako.service.nix
index 1f210c74..190b986d 100644
--- a/modules/sway/mako.service.nix
+++ b/modules/sway/mako.service.nix
@@ -1,10 +1,11 @@
-{ pkgs, ... }:
+pkgs:
{
Unit = {
Description = "Lightweight Wayland notification daemon";
Documentation = [ "man:mako(1)" ];
BindsTo = [ "sway-session.target" ];
After = [ "sway-session.target" ];
+ # ConditionEnvironment requires systemd v247 to work correctly
ConditionEnvironment = [ "WAYLAND_DISPLAY" ];
};
Service = {
diff --git a/modules/sway/sway-session.target.nix b/modules/sway/sway-session.target.nix
index 7b25376a..3eb4d24c 100644
--- a/modules/sway/sway-session.target.nix
+++ b/modules/sway/sway-session.target.nix
@@ -1,4 +1,4 @@
-{ pkgs, ... }:
+pkgs:
{
Unit = {
Description = "sway compositor session";
diff --git a/modules/sway/sway.service.nix b/modules/sway/sway.service.nix
index 0d0d782c..95efc3e6 100644
--- a/modules/sway/sway.service.nix
+++ b/modules/sway/sway.service.nix
@@ -1,4 +1,4 @@
-{ pkgs, ... }:
+pkgs:
{
Unit = {
Description = "sway - SirCmpwn's Wayland window manager";
diff --git a/modules/sway/swayidle.service.nix b/modules/sway/swayidle.service.nix
index 80a04518..597a8779 100644
--- a/modules/sway/swayidle.service.nix
+++ b/modules/sway/swayidle.service.nix
@@ -1,4 +1,4 @@
-{ pkgs, psCfg, ... }:
+pkgs:
{
Unit = {
Description = "Idle manager for Wayland";
@@ -9,16 +9,13 @@
};
Service = {
Type = "simple";
- Environment = "PATH=/run/current-system/sw/bin:${pkgs.sway}/bin:${pkgs.swaylock-bg}/bin:${pkgs.swayidle}/bin";
- ExecStart = ''swayidle -w \
- after-resume 'swaymsg "output * dpms on"' \
- before-sleep 'swaylock-bg' '' + (if psCfg.paranoia.enable then '' \
- timeout 120 'swaymsg "output * dpms off"' resume 'swaymsg "output * dpms on"' \
- timeout 150 'systemctl hibernate'
- '' else '' \
- timeout 600 'swaylock-bg' \
- timeout 900 'swaymsg "output * dpms off"' resume 'swaymsg "output * dpms on"'
- '');
+ Environment = "PATH=/run/current-system/sw/bin:${pkgs.sway}/bin:${pkgs.swaylock}/bin:${pkgs.swaylock-bg}/bin";
+ ExecStart = ''${pkgs.swayidle}/bin/swayidle -w \
+ timeout 600 'swaylock-bg' \
+ timeout 900 'swaymsg "output * dpms off"' \
+ resume 'swaymsg "output * dpms on"' \
+ before-sleep 'swaylock-bg'
+ '';
};
Install = {
WantedBy = [ "sway-session.target" ];
diff --git a/modules/sway/waybar.service.nix b/modules/sway/waybar.service.nix
index 0237612f..ee5e8938 100644
--- a/modules/sway/waybar.service.nix
+++ b/modules/sway/waybar.service.nix
@@ -1,12 +1,11 @@
-{ pkgs, ... }:
+pkgs:
{
Unit = {
Description = "Highly customizable Wayland bar for Sway and Wlroots based compositors.";
Documentation = "https://github.com/Alexays/Waybar/wiki/";
BindsTo = [ "sway-session.target" ];
- After = [ "sway-session.target" "network-online.target" ];
+ After = [ "graphical-session-pre.target" "network-online.target" ];
Wants = [ "graphical-session-pre.target" "network-online.target" "blueman-applet.service" ];
- ConditionEnvironment = [ "WAYLAND_DISPLAY" ];
};
Service = {
diff --git a/modules/sway/xsettingsd.service.nix b/modules/sway/xsettingsd.service.nix
index db3e842c..0d729cb2 100644
--- a/modules/sway/xsettingsd.service.nix
+++ b/modules/sway/xsettingsd.service.nix
@@ -1,4 +1,4 @@
-{ pkgs, ... }:
+pkgs:
{
Unit = {
Description = "X Settings Daemon";
diff --git a/modules/sway/ydotool.service.nix b/modules/sway/ydotool.service.nix
index 24b64432..d53bfcd7 100644
--- a/modules/sway/ydotool.service.nix
+++ b/modules/sway/ydotool.service.nix
@@ -1,4 +1,4 @@
-{ pkgs, ... }:
+pkgs:
{
Unit = {
Description = "ydotool - Generic command-line automation tool (no X!)";
diff --git a/modules/terminal-life/default.nix b/modules/terminal-life/default.nix
index 6bd0312f..8ecb9919 100644
--- a/modules/terminal-life/default.nix
+++ b/modules/terminal-life/default.nix
@@ -7,14 +7,6 @@ in
{
options.pub-solar.terminal-life = {
enable = mkEnableOption "Life in black and white";
-
- lite = mkOption {
- description = ''
- Enable a lite edition of terminal-life with less modules and a reduced package set.
- '';
- default = false;
- type = types.bool;
- };
};
config = mkIf cfg.enable {
diff --git a/modules/terminal-life/nvim/default.nix b/modules/terminal-life/nvim/default.nix
index 6ca59da6..09a25b2f 100644
--- a/modules/terminal-life/nvim/default.nix
+++ b/modules/terminal-life/nvim/default.nix
@@ -1,7 +1,6 @@
{ config, pkgs, ... }:
let
psCfg = config.pub-solar;
- cfg = config.pub-solar.terminal-life;
xdg = config.home-manager.users."${psCfg.user.name}".xdg;
preview-file = pkgs.writeShellScriptBin "preview-file" (import ./preview-file.nix pkgs);
@@ -87,7 +86,7 @@ in
withRuby = true;
withPython3 = true;
- extraPackages = with pkgs; lib.mkIf (!cfg.lite) [
+ extraPackages = with pkgs; [
ccls
gopls
nodejs
diff --git a/modules/terminal-life/zsh/default.nix b/modules/terminal-life/zsh/default.nix
index 382aa728..4c64dede 100644
--- a/modules/terminal-life/zsh/default.nix
+++ b/modules/terminal-life/zsh/default.nix
@@ -39,49 +39,21 @@ in
nixos-option = "nixos-option -I nixpkgs=${self}/lib/compat";
myip = "dig +short myip.opendns.com @208.67.222.222 2>&1";
};
- plugins = [
- {
- # will source ohmyzsh/plugins/z/
- name = "zsh-plugins-z";
- file = "plugins/z/z.sh";
- src = pkgs.fetchFromGitHub {
- owner = "ohmyzsh";
- repo = "ohmyzsh";
- rev = "249c708ed3a4a7a63d16a6e911a46b6fb9623cbd";
- sha256 = "sha256-NAVotL5RxpS/zKnO+ngMIjv787lqc1dj/c4blQrQcvU=";
- };
- }
- {
- name = "zsh-powerlevel10k";
- file = "powerlevel10k.zsh-theme";
- src = pkgs.fetchFromGitHub {
- owner = "romkatv";
- repo = "powerlevel10k";
- rev = "2dd6a29e4d7a33bfef10973d6550e087be37ddee";
- sha256 = "sha256-9vc4cMBCNOmPOyzGwnPeMrXXyQUq4pC9Du3AWl9+Rys=";
- };
- }
- {
- name = "zsh-fast-syntax-highlighting";
- file = "F-Sy-H.plugin.zsh";
- src = pkgs.fetchFromGitHub {
- owner = "z-shell";
- repo = "F-Sy-H";
- rev = "c4bdc485b67b58351a24f21fcac92c9e0232b939";
- sha256 = "sha256-uXBGIdJwubuueNhQRdGxPUi0eJN17cflYAuHTjeQ8FQ=";
- };
- }
- {
- name = "zsh-nix-shell";
- file = "nix-shell.plugin.zsh";
- src = pkgs.fetchFromGitHub {
- owner = "chisui";
- repo = "zsh-nix-shell";
- rev = "af6f8a266ea1875b9a3e86e14796cadbe1cfbf08";
- sha256 = "sha256-BjgMhILEL/qdgfno4LR64LSB8n9pC9R+gG7IQWwgyfQ=";
- };
- }
- ];
+ zplug = {
+ enable = true;
+ plugins = [
+ {
+ name = "plugins/z";
+ tags = [ "from:oh-my-zsh" ];
+ }
+ {
+ name = "romkatv/powerlevel10k";
+ tags = [ "as:theme" "depth:1" ];
+ }
+ { name = "zdharma/fast-syntax-highlighting"; }
+ { name = "chisui/zsh-nix-shell"; }
+ ];
+ };
initExtra = ''
bindkey -v
diff --git a/modules/user/default.nix b/modules/user/default.nix
index 7c869380..2fd5958e 100644
--- a/modules/user/default.nix
+++ b/modules/user/default.nix
@@ -23,7 +23,7 @@ in
};
publicKeys = mkOption {
description = "User SSH public keys";
- type = types.listOf types.str;
+ type = types.listOf types.path;
default = [ ];
};
fullName = mkOption {
diff --git a/modules/x-os/boot.nix b/modules/x-os/boot.nix
new file mode 100644
index 00000000..87c5b7d5
--- /dev/null
+++ b/modules/x-os/boot.nix
@@ -0,0 +1,34 @@
+{ config, pkgs, lib, ... }:
+let
+ cfg = config.pub-solar.x-os;
+in
+with lib;
+{
+ options.pub-solar.x-os.iso-options.enable = mkOption {
+ type = types.bool;
+ default = false;
+ description = "Feature flag for iso builds";
+ };
+
+ options.pub-solar.x-os.disk-encryption-active = mkOption {
+ type = types.bool;
+ default = true;
+ description = "Whether it should be assumed that there is a cryptroot device";
+ };
+
+ config = {
+ # Enable plymouth for better experience of booting
+ boot.plymouth.enable = true;
+
+ # Mount / luks device in initrd
+ # Allow fstrim to work on it.
+ # The ! makes this enabled by default
+ boot.initrd = mkIf (!cfg.iso-options.enable && cfg.disk-encryption-active) {
+ luks.devices."cryptroot" = {
+ allowDiscards = true;
+ };
+ };
+
+ boot.loader.systemd-boot.enable = true;
+ };
+}
diff --git a/modules/x-os/default.nix b/modules/x-os/default.nix
new file mode 100644
index 00000000..6276bf5f
--- /dev/null
+++ b/modules/x-os/default.nix
@@ -0,0 +1,7 @@
+{ ... }: {
+ imports = [
+ ./boot.nix
+ ./i18n.nix
+ ./networking.nix
+ ];
+}
diff --git a/modules/core/i18n.nix b/modules/x-os/i18n.nix
similarity index 100%
rename from modules/core/i18n.nix
rename to modules/x-os/i18n.nix
diff --git a/modules/x-os/networking.nix b/modules/x-os/networking.nix
new file mode 100644
index 00000000..5ff41ddc
--- /dev/null
+++ b/modules/x-os/networking.nix
@@ -0,0 +1,60 @@
+{ config, pkgs, lib, ... }:
+
+with lib;
+
+let cfg = config.pub-solar.x-os;
+in
+{
+ options.pub-solar.x-os = {
+ binaryCaches = mkOption {
+ type = types.listOf types.str;
+ default = [ ];
+ description = "Binary caches to use.";
+ };
+ publicKeys = mkOption {
+ type = types.listOf types.str;
+ default = [ ];
+ description = "Public keys of binary caches.";
+ };
+ iwdConfig = mkOption {
+ type = with types; nullOr (attrsOf (attrsOf (oneOf [ bool int str ])));
+ default = null;
+ description = "Configuration of iNet Wireless Daemon.";
+ };
+ };
+ config = {
+ networking.networkmanager = {
+ # Enable networkmanager. REMEMBER to add yourself to group in order to use nm related stuff.
+ enable = true;
+ };
+
+ # Customized binary caches list (with fallback to official binary cache)
+ nix.binaryCaches = cfg.binaryCaches;
+ nix.binaryCachePublicKeys = cfg.publicKeys;
+
+ # These entries get added to /etc/hosts
+ networking.hosts = {
+ "127.0.0.1" = [ "cups.local" "help.local" "caddy.local" ];
+ };
+
+ # Caddy reverse proxy for local services like cups
+ services.caddy = {
+ enable = true;
+ globalConfig = ''
+ default_bind 127.0.0.1
+ auto_https off
+ '';
+ extraConfig = ''
+ cups.local:80 {
+ request_header Host localhost:631
+ reverse_proxy unix//run/cups/cups.sock
+ }
+
+ help.local:80 {
+ root * ${pkgs.psos-docs}/lib/html
+ file_server
+ }
+ '';
+ };
+ };
+}
diff --git a/overlays/overrides.nix b/overlays/overrides.nix
index f216e427..4a85b71f 100644
--- a/overlays/overrides.nix
+++ b/overlays/overrides.nix
@@ -10,29 +10,21 @@ channels: final: prev: {
discord
element-desktop
rage
- nix-index
nixpkgs-fmt
qutebrowser
signal-desktop
starship
deploy-rs
- nix
tdesktop
arduino
arduino-cli
- steam
- firefox
;
inherit (channels.pub-solar)
yubikey-agent
;
- inherit (channels.master)
- factorio-headless
- ;
-
haskellPackages = prev.haskellPackages.override
(old: {
diff --git a/overlays/rnix-lsp.nix b/overlays/rnix-lsp.nix
deleted file mode 100644
index 62c0f2b0..00000000
--- a/overlays/rnix-lsp.nix
+++ /dev/null
@@ -1,18 +0,0 @@
-final: prev: {
- rnix-lsp = prev.rnix-lsp.overrideAttrs (oldAttrs: rec {
- version = "unstable-2022-07-28";
-
- src = prev.fetchFromGitHub {
- owner = "nix-community";
- repo = "rnix-lsp";
- rev = "ff18e04551a39ccdab0ff9c83926db3807b23478";
- sha256 = "sha256-4OIpATLdPQvryyhRQPELeqNYC0n6PCyjD6LCPdwOztc=";
- };
-
- cargoDeps = oldAttrs.cargoDeps.overrideAttrs (prev.lib.const {
- name = "rnix-lsp-vendor.tar.gz";
- inherit src;
- outputHash = "sha256-SroynaHaFpvKlMSEagoGQhZcY7A0tE4xTbUXYFcneo8=";
- });
- });
-}
diff --git a/pkgs/default.nix b/pkgs/default.nix
index c11a09cf..8d595faf 100644
--- a/pkgs/default.nix
+++ b/pkgs/default.nix
@@ -13,11 +13,14 @@ with final; {
s = writeShellScriptBin "s" (import ./s.nix final);
sway-launcher = writeScriptBin "sway-launcher" (import ./sway-launcher.nix final);
sway-service = writeShellScriptBin "sway-service" (import ./sway-service.nix final);
- swaylock-bg = writeShellScriptBin "swaylock-bg" (import ./swaylock-bg.nix final);
+ swaylock-bg = writeScriptBin "swaylock-bg" (import ./swaylock-bg.nix final);
toggle-kbd-layout = writeShellScriptBin "toggle-kbd-layout" (import ./toggle-kbd-layout.nix final);
uhk-agent = import ./uhk-agent.nix final;
wcwd = writeShellScriptBin "wcwd" (import ./wcwd.nix final);
- drone-docker-runner = writeShellScriptBin "drone-docker-runner" (import ./drone-docker-runner.nix final);
record-screen = writeShellScriptBin "record-screen" (import ./record-screen.nix final);
+
+ # ps-fixes
+
scan2paperless = writeShellScriptBin "scan2paperless" (import ./scan2paperless.nix final);
+ drone-docker-runner = writeShellScriptBin "drone-docker-runner" (import ./drone-docker-runner.nix final);
}
diff --git a/pkgs/drone-docker-runner.nix b/pkgs/drone-docker-runner.nix
index 25de349f..cf6dc802 100644
--- a/pkgs/drone-docker-runner.nix
+++ b/pkgs/drone-docker-runner.nix
@@ -6,7 +6,7 @@ self: with self; ''
--env=DRONE_RPC_PROTO=$DRONE_RPC_PROTO \
--env=DRONE_RPC_HOST=$DRONE_RPC_HOST \
--env=DRONE_RPC_SECRET=$(${self.libsecret}/bin/secret-tool lookup drone rpc-secret) \
- --env=DRONE_RUNNER_CAPACITY=8 \
+ --env=DRONE_RUNNER_CAPACITY=4 \
--env=DRONE_RUNNER_NAME=$(${self.inetutils}/bin/hostname) \
--publish=30010:30010 \
--restart=always \
diff --git a/pkgs/sway-launcher.nix b/pkgs/sway-launcher.nix
index 57c7afe4..afa09d07 100644
--- a/pkgs/sway-launcher.nix
+++ b/pkgs/sway-launcher.nix
@@ -23,7 +23,7 @@ self: with self; ''
# search command list
command_str=$(printf "%s\n" "''${command_history}" "''${command_list}" | \
sed -E 's/^[0-9]+ (.+)$/\1/' | \
- fzf --color=16 --exact --no-extended --print-query --no-sort | \
+ fzf --exact --no-extended --print-query --no-sort | \
tail -n1) || exit 1
if [ "$command_str" = "" ]; then
diff --git a/pkgs/sway-service.nix b/pkgs/sway-service.nix
index 2ab84c62..f0b97ee7 100644
--- a/pkgs/sway-service.nix
+++ b/pkgs/sway-service.nix
@@ -1,6 +1,6 @@
self: with self; ''
# first import environment variables from the login manager
- systemctl --user import-environment;
+ systemctl --user import-environment
# then start the service
exec systemctl --wait --user start sway.service
''
diff --git a/pkgs/swaylock-bg.nix b/pkgs/swaylock-bg.nix
index 75bcd7de..b55c32ae 100644
--- a/pkgs/swaylock-bg.nix
+++ b/pkgs/swaylock-bg.nix
@@ -3,17 +3,18 @@ self: with self; ''
# swaylock
# Make sure we aren't running twice
- RUNNING=$(${procps}/bin/pgrep -c ${swaylock}/bin/swaylock)
- if [ "$RUNNING" -ne 0 ]; then
+ RUNNING=$(ps -A | grep swaylock | wc -l)
+ if [ $RUNNING -ne 0 ]; then
exit 0
fi
- IMAGE="$XDG_CONFIG_HOME/wallpaper.jpg"
+ IMAGE=$XDG_CONFIG_HOME/wallpaper.jpg
LOCKARGS=""
- for OUTPUT in $(${sway}/bin/swaymsg -t get_outputs | ${jq}/bin/jq -r '.[].name')
+ for OUTPUT in `${sway}/bin/swaymsg -t get_outputs | jq -r '.[].name'`
do
LOCKARGS="''${LOCKARGS} --image ''${OUTPUT}:''${IMAGE}"
+ IMAGES="''${IMAGES} ''${IMAGE}"
done
exec ${swaylock}/bin/swaylock $LOCKARGS
''
diff --git a/profiles/base-user/default.nix b/profiles/base-user/default.nix
index 374dca40..9ff21c8e 100644
--- a/profiles/base-user/default.nix
+++ b/profiles/base-user/default.nix
@@ -25,7 +25,7 @@ in
];
initialHashedPassword = if psCfg.user.password != null then psCfg.user.password else "";
shell = pkgs.zsh;
- openssh.authorizedKeys.keys = if psCfg.user.publicKeys != null then psCfg.user.publicKeys else [ ];
+ openssh.authorizedKeys.keyFiles = if psCfg.user.publicKeys != null then psCfg.user.publicKeys else [ ];
};
};
}
diff --git a/profiles/base-user/session-variables.nix b/profiles/base-user/session-variables.nix
index e922781b..5bbfa8ee 100644
--- a/profiles/base-user/session-variables.nix
+++ b/profiles/base-user/session-variables.nix
@@ -1,4 +1,4 @@
-{ config, pkgs, lib, ... }:
+{ config, pkgs, ... }:
let
psCfg = config.pub-solar;
wlroots = psCfg.graphical.wayland;
@@ -77,22 +77,10 @@ let
# TELEMETRY BS
VUEDX_TELEMETRY = "off";
};
-
- envListNames = lib.attrsets.mapAttrsToList (name: value: name) variables;
-
- # Here we merge an extra variable into the attrset called FULL_ENV_LIST.
- # It's a list of the variable names defined above.
- # We can use this to tell `systemctl import-environment` to import the full list above.
- variablesWithMeta = lib.attrsets.zipAttrsWith (name: values: builtins.head values) [
- variables
- { IMPORT_ENVIRONMENT_ENV_LIST = lib.lists.foldl (a: b: a + " " + b) "IMPORT_ENVIRONMENT_ENV_LIST" envListNames; }
- ];
in
{
home-manager = pkgs.lib.setAttrByPath [ "users" psCfg.user.name ] {
- home.sessionVariables = variablesWithMeta;
- systemd.user.sessionVariables = variablesWithMeta;
+ home.sessionVariables = variables;
+ systemd.user.sessionVariables = variables;
};
-
- environment.variables = variablesWithMeta;
}
diff --git a/profiles/core/default.nix b/profiles/core/default.nix
index d146bfb1..f3136372 100644
--- a/profiles/core/default.nix
+++ b/profiles/core/default.nix
@@ -117,8 +117,7 @@ in
# For rage encryption, all hosts need a ssh key pair
services.openssh = {
enable = true;
- openFirewall = lib.mkDefault true;
- passwordAuthentication = false;
+ openFirewall = lib.mkDefault false;
};
# Service that makes Out of Memory Killer more effective
diff --git a/profiles/core/starship.toml b/profiles/core/starship.toml
new file mode 100644
index 00000000..6ed366b5
--- /dev/null
+++ b/profiles/core/starship.toml
@@ -0,0 +1,95 @@
+[aws]
+symbol = " "
+
+[character]
+success_symbol = "[❯](bold purple)"
+vicmd_symbol = "[❮](bold purple)"
+
+[battery]
+full_symbol = ""
+charging_symbol = ""
+discharging_symbol = ""
+
+[conda]
+symbol = " "
+
+[directory]
+style = "cyan"
+read_only = " 🔒"
+
+[docker]
+symbol = " "
+
+[elixir]
+symbol = " "
+
+[elm]
+symbol = " "
+
+[git_branch]
+format = "[$symbol$branch]($style) "
+symbol = " "
+style = "bold dimmed white"
+
+[git_status]
+format = '([「$all_status$ahead_behind」]($style) )'
+conflicted = "⚠️"
+ahead = "⟫${count} "
+behind = "⟪${count}"
+diverged = "🔀 "
+untracked = "📁 "
+stashed = "↪ "
+modified = "𝚫 "
+staged = "✔ "
+renamed = "⇆ "
+deleted = "✘ "
+style = "bold bright-white"
+
+[golang]
+symbol = " "
+
+[haskell]
+symbol = " "
+
+[hg_branch]
+symbol = " "
+
+[java]
+symbol = " "
+
+[julia]
+symbol = " "
+
+[memory_usage]
+symbol = " "
+disabled = false
+
+[nim]
+symbol = " "
+
+[nix_shell]
+format = '[$symbol$state]($style) '
+symbol = " "
+pure_msg = "λ"
+impure_msg = "⎔"
+
+[nodejs]
+symbol = " "
+
+[package]
+symbol = " "
+
+[php]
+symbol = " "
+
+[python]
+symbol = " "
+
+[ruby]
+symbol = " "
+
+[rust]
+symbol = " "
+
+[status]
+disabled = false
diff --git a/profiles/iot/default.nix b/profiles/iot/default.nix
deleted file mode 100644
index 185a9ce0..00000000
--- a/profiles/iot/default.nix
+++ /dev/null
@@ -1,8 +0,0 @@
-{ self, config, lib, pkgs, ... }:
-let inherit (lib) fileContents;
-in
-{
- pub-solar.graphical.enable = false;
- pub-solar.x-os.localProxyService.enable = false;
- pub-solar.sway.enable = false;
-}
diff --git a/profiles/pub-solar-iso/default.nix b/profiles/pub-solar-iso/default.nix
index 4aa8c6fd..24b5e1b3 100644
--- a/profiles/pub-solar-iso/default.nix
+++ b/profiles/pub-solar-iso/default.nix
@@ -6,6 +6,6 @@ in
config = {
pub-solar.graphical.wayland.software-renderer.enable = true;
pub-solar.sway.terminal = "foot";
- pub-solar.core.iso-options.enable = true;
+ pub-solar.x-os.iso-options.enable = true;
};
}
diff --git a/secrets/drone-runner-exec-config b/secrets/drone-runner-exec-config
deleted file mode 100644
index 0b7e2e90..00000000
Binary files a/secrets/drone-runner-exec-config and /dev/null differ
diff --git a/secrets/dyndns-droppie.key b/secrets/dyndns-droppie.key
deleted file mode 100644
index d4f7e999..00000000
--- a/secrets/dyndns-droppie.key
+++ /dev/null
@@ -1,27 +0,0 @@
-age-encryption.org/v1
--> ssh-rsa kFDS0A
-lbrJzpCXpf3BJYL80d2vD/b4raoPnUKV0D9Ka9yKb72W3ATfA/Cqq7vpisHRnwyj
-3pt1TfrPzti/8ZKDqY/Zw171jQbOF6zW45z4m8yJu4J1LYXh8yYrTR3YPwhPoGYm
-eZJWWj2YghqCFC7vdL/wZFjkStxwBGgrJfNOxJBcXOpUX2TOzfdNAgJ/pEkvdd/L
-jktiU5ITt7KXruwSEXRzHVfmntl4SaqDqYfeb0Y0q2a1oMpxTnBKcYXj6dYcZIHv
-Lm8HX0JsIiThz/DXB4sP2O5GlGeYyibj2iMSCsCqadwDpUndVtJnzFgjSQD5A0gd
-enNTYly3GSmC9TWt/r2VHHyneAnJ3HQKB5hUEqxPz9peemnvfTA89SIGHddmkXfY
-XSeN5WJnSG0+WAOwrpJjzl9CgUg9xJS7dDqVob3CwL9oVEQP8FcuuyqCg72ppd4J
-fdseq5/R+HuVnh6sEUHoaHEDidHtTrpE2Rd49Tesj/BT+YrJyQ/kQqHmy9RiLU2f
-DSRwLO4/qHF6W8UfuF2N08aMxRpxqXPWTjI/vHxoSJRcSqaofF42x50OQU8lY96c
-8bPlDPB7HOBg+7bVvOQCaR3+KRuOx+HYpeMwEokQTwCke+frPfXorilNbAcaFUp4
-QiU1sUZia/FOZ+j47+6pkfC2DfLpiNL2TLWYcNtIzUc
--> ssh-ed25519 7Wns0A aKiZ8iw+Ub5rByBef0apOn6lG5Bv6tzFCiBu3DN6sSg
-58+9kySg3ajO7E5V87b/qRu9axpu2hQUuY/cVTt2YdI
--> ssh-rsa wVtlwQ
-RbrfuwS5zQzL9yMWFDSnWj9cQFLirTH37Xf79Dis2CJIDd83vmlmGNY5x1aPpZoZ
-J6XDhibGTJc02DYuNVIE1IXm0x9tc6Z9PTT+WiAFt1JuKHguXTWLRMM9HmyvWWDg
-bFsRDAcYup+SK5d+ME+XooDGueC822rAjkGIRHNSCimGwuLpDRKqyyVfYA+dcfiP
-EoYH7x4S09jYRr1C5EkbraLbm1vijc5ikJw3b42KKbyo3wDwKga+Vk2nl2AtgjZp
-KipZlyjs+IjMRXX5IBpgoRtXcvHuidsOSc+guRo0ihF9MbzRc/Tt2g0V7t3KjeT0
-SJDLmHOos2RKTmx06aidDg
--> Dz(k-grease ~FF p m)E{J3E
-7Igp3pclCAzAmeky5cPqlIzcITT+0jvieQe7ruSxRYRYqpYU7tMQFmHuNUahp+BP
-MzOYiM+PIQmn
---- IC9SI76EjaFZxQ5odEeIv49n/O8uOdpM6LE1Z7dtHg4
-l%uE\?2\&wG&@W~9"^Ɔon^xOIuO21c*m%)#جeI6A/i
\ No newline at end of file
diff --git a/secrets/secrets.nix b/secrets/secrets.nix
index bf4a7c8e..65b6ed99 100644
--- a/secrets/secrets.nix
+++ b/secrets/secrets.nix
@@ -8,9 +8,6 @@ let
chocolatebar-host = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAINZT3QrKugNTWNOwYziQnxrT5zFqWQDafWjScDuIpMhN root@chocolatebar";
chocolatebar-user = "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDwyNsGCMuyI9x2IxYEbYIL6oYsEfe1wqhHaRxSnK9oc10ge1LJni5o7g6XgryoQpCD9YenImcCxwkKblmlLQ2327uoVC2PUo07li1uT0eIPk0TQoxwp6besFs7/LEzZlgWQsc3gkEXmjk/E0mu0U6z2fkqciJ/ZxWYt9fLP6jBG47U9878rSaZ7k7Ilv6oRA3suArH189k1nerk/tonS4EWXeHZxHh/Eu0tqwmxN/6+g2GicYn6b+MbFQVdQAkctqT5Yz9USm9UKzbaAuZ799u0dJzagHm9JJZOr8r11ENtAkY9kAzRzm3u/ACiSdVzyLdjAK6m0dIPhp3OhedzuHiI6/wRll60tYtQTH1XwUpVbtir3+DT+jwZgO1zH3yL4iNh79kuUo+UEg1ZmGkSZRzSS2vb5qr0J5aSJmCd5sNB7a01PTtSlQPOqSF9PB+UmcLDF7JoKFub0KT/gRZ5neZkXTYQ/Y05qtaaFVlOVISijnm+sLUvKBv6OW8oYXIHBk= ben@chocolatebar";
- droppie-host = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBDuXuPPDXTyJgy4JRwbKcPbawvVB1Il2neyRWb4O5sJ root@nixos";
- droppie-user = "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCnYTlTmHCl6LOkexqRR9LqjOoFgt9TQ4VzHQGRHJMzF/AGcDRoqC+pBLFSTzRb5/ikAOsb32XHyKVg4nNdJeQshO11QtDmkCB02D/XcIXxnNQ5A8CztT2az5xJtbbWSdamMnHBLcqLiwoLmXbERpdlt8jNqMHrz+bjCUGYVAFSfc/WdIs6EATJ1eF0VFxv7nUh4qhgStABSwhNsnoYOC/DOBSA9aBP1f5Fz9QHUioPTGi2hRwbTbtFUvTrymPpWVFRApa1zvGXcr4YUCm7ia1ZlZKzRpsPkwLxb8Omm4bGmR0cAVwVhVRySnhpCTwbIBLyw+H8PvKWBBba1NAKyMij root@droppie";
-
allKeys = [
bbcom
@@ -34,13 +31,6 @@ let
chocolatebar-host
chocolatebar-user
];
-
- droppieKeys = [
- bbcom
-
- droppie-host
- droppie-user
- ];
in
{
"keyfile-biolimo.bin".publicKeys = biolimoKeys;
@@ -52,9 +42,5 @@ in
"vnc-cert-chocolatebar.pem".publicKeys = chocolatebarKeys;
"vnc-key-chocolatebar.pem".publicKeys = chocolatebarKeys;
- "drone-runner-exec-config".publicKeys = allKeys;
-
- "dyndns-droppie.key".publicKeys = droppieKeys;
-
"mopidy.conf".publicKeys = allKeys;
}
diff --git a/shell/default.nix b/shell/default.nix
index 597a2d2d..d22b3af4 100644
--- a/shell/default.nix
+++ b/shell/default.nix
@@ -1,6 +1,7 @@
{ self, inputs, ... }:
{
modules = with inputs; [
+ bud.devshellModules.bud
];
exportedModules = [
./devos.nix
diff --git a/shell/devos.nix b/shell/devos.nix
index 9aefcc6f..f799ca03 100644
--- a/shell/devos.nix
+++ b/shell/devos.nix
@@ -1,22 +1,12 @@
-{ pkgs, extraModulesPath, inputs, lib, ... }:
+{ pkgs, extraModulesPath, inputs, ... }:
let
- inherit (pkgs)
- agenix
- cachix
- editorconfig-checker
- mdbook
- nix
- nixpkgs-fmt
- nvfetcher
- ;
-
hooks = import ./hooks;
pkgWithCategory = category: package: { inherit package category; };
- devos = pkgWithCategory "devos";
linter = pkgWithCategory "linter";
docs = pkgWithCategory "docs";
+ devos = pkgWithCategory "devos";
in
{
@@ -44,7 +34,7 @@ in
'');
commands = with pkgs; [
- (devos nix)
+ (devos nixUnstable)
(devos agenix)
{
category = "devos";
@@ -54,15 +44,15 @@ in
}
(linter nixpkgs-fmt)
(linter editorconfig-checker)
-
+ # (docs python3Packages.grip) too many deps
(docs mdbook)
- ]
- ++ lib.optionals (!pkgs.stdenv.buildPlatform.isi686) [
- (devos cachix)
- ]
- ++ lib.optionals (pkgs.stdenv.hostPlatform.isLinux && !pkgs.stdenv.buildPlatform.isDarwin) [
- (devos inputs.nixos-generators.defaultPackage.${pkgs.system})
(devos deploy-rs)
]
+ ++ lib.optional
+ (system != "i686-linux")
+ (devos cachix)
+ ++ lib.optional
+ (system != "aarch64-darwin")
+ (devos inputs.nixos-generators.defaultPackage.${pkgs.system})
;
}
diff --git a/shell/hooks/pre-commit.sh b/shell/hooks/pre-commit.sh
index a7fa9083..985d3b40 100755
--- a/shell/hooks/pre-commit.sh
+++ b/shell/hooks/pre-commit.sh
@@ -14,16 +14,13 @@ nix_files=($($diff -- '*.nix'))
all_files=($($diff))
# Format staged nix files.
-if (( ${#nix_files[@]} != 0 )); then
+if [[ -n "${nix_files[@]}" ]]; then
nixpkgs-fmt "${nix_files[@]}" \
&& git add "${nix_files[@]}"
fi
# check editorconfig
-if (( ${#all_files[@]} != 0 )); then
- editorconfig-checker -- "${all_files[@]}"
-fi
-
+editorconfig-checker -- "${all_files[@]}"
if [[ $? != '0' ]]; then
printf "%b\n" \
"\nCode is not aligned with .editorconfig" \
diff --git a/tests/first-test.nix b/tests/first-test.nix
deleted file mode 100644
index 251779a1..00000000
--- a/tests/first-test.nix
+++ /dev/null
@@ -1,87 +0,0 @@
-{ pkgs, lib, ... }:
-{
- name = "firstTest";
-
- nodes.test-machine = { suites ? null, ... }: {
- imports = suites.iso;
-
- home-manager.users.pub-solar.programs.zsh.shellAliases = {
- test-x11 = "glinfo | tee /tmp/test-x11.out && touch /tmp/test-x11-exit-ok";
- test-wayland = "wayland-info | tee /tmp/test-wayland.out && touch /tmp/test-wayland-exit-ok";
- };
-
- # source: https://github.com/NixOS/nixpkgs/blob/nixos-unstable/nixos/tests/sway.nix
- environment = {
- # For glinfo and wayland-info:
- systemPackages = with pkgs; [ mesa-demos wayland-utils alacritty ];
- # Use a fixed SWAYSOCK path (for swaymsg):
- variables = {
- "SWAYSOCK" = "/tmp/sway-ipc.sock";
- # TODO: Investigate if we can get hardware acceleration to work (via
- # virtio-gpu and Virgil). We currently have to use the Pixman software
- # renderer since the GLES2 renderer doesn't work inside the VM (even
- # with WLR_RENDERER_ALLOW_SOFTWARE):
- # "WLR_RENDERER_ALLOW_SOFTWARE" = "1";
- "WLR_RENDERER" = "pixman";
- };
-
- # To help with OCR:
- etc."xdg/foot/foot.ini".text = lib.generators.toINI { } {
- main = {
- font = "inconsolata:size=14";
- };
- colors = rec {
- foreground = "000000";
- background = "ffffff";
- regular2 = foreground;
- };
- };
- };
-
- fonts.fonts = [ pkgs.inconsolata ];
-
- # Need to switch to a different GPU driver than the default one (-vga std) so that Sway can launch:
- virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ];
- virtualisation.cores = 4;
- virtualisation.memorySize = 2048;
- };
-
- enableOCR = true;
-
- testScript = ''
- import shlex
- def swaymsg(command: str, succeed=True):
- with machine.nested(f"sending swaymsg {command!r}" + " (allowed to fail)" * (not succeed)):
- (machine.succeed if succeed else machine.execute)(
- f"su - pub-solar -c {shlex.quote('swaymsg -- ' + command)}"
- )
-
-
- machine.wait_for_unit("multi-user.target")
-
- # To check the version:
- print(machine.succeed("sway --version"))
-
- # Wait for Sway to complete startup:
- machine.wait_for_file("/run/user/1000/wayland-1")
- machine.wait_for_file("/tmp/sway-ipc.sock")
-
- # Start a terminal (foot) on workspace 3:
- machine.wait_for_text("1")
- machine.send_key("meta_l-3")
- machine.sleep(3)
- machine.send_key("meta_l-ret")
- machine.sleep(10)
- machine.send_chars("whoami\n")
- machine.sleep(3)
- machine.wait_for_text("pub-solar")
- machine.send_chars("test-wayland\n")
- machine.wait_for_file("/tmp/test-wayland-exit-ok")
- print(machine.succeed("cat /tmp/test-wayland.out"))
- machine.copy_from_vm("/tmp/test-wayland.out")
- machine.sleep(3)
- machine.screenshot("foot_wayland_info")
- machine.send_key("meta_l-shift-q")
- machine.wait_until_fails("pgrep foot")
- '';
-}
diff --git a/tests/second-test.nix b/tests/second-test.nix
deleted file mode 100644
index d6409820..00000000
--- a/tests/second-test.nix
+++ /dev/null
@@ -1,14 +0,0 @@
-{ }:
-{
- name = "secondTest";
-
- nodes.test-machine2 = { suites ? null, ... }: {
- imports = [
- suites.iso
- ];
- };
-
- testScript = ''
- machines[0].systemctl("is-system-running --wait")
- '';
-}
diff --git a/users/ben/.config/msmtp/config b/users/ben/.config/msmtp/config
index d3fc920b..dc324118 100644
--- a/users/ben/.config/msmtp/config
+++ b/users/ben/.config/msmtp/config
@@ -48,16 +48,6 @@ account admins@pub.solar
tls on
tls_trust_file /etc/ssl/certs/ca-certificates.crt
-account crew@pub.solar
- host mail.greenbaum.cloud
- port 587
- protocol smtp
- auth on
- from crew@pub.solar
- user crew@pub.solar
- tls on
- tls_trust_file /etc/ssl/certs/ca-certificates.crt
-
account mail@b12f.io
host mail.b12f.io
port 587
diff --git a/users/ben/.config/mutt/admins@pub.solar.signature b/users/ben/.config/mutt/admins@pub.solar.signature
index d24a0c1f..d47e6631 100644
--- a/users/ben/.config/mutt/admins@pub.solar.signature
+++ b/users/ben/.config/mutt/admins@pub.solar.signature
@@ -1,4 +1,6 @@
+--
+
pub.solar Admins (they/them)
MAIL: admins@pub.solar
diff --git a/users/ben/.config/mutt/b.baedorf@openproject.com.signature b/users/ben/.config/mutt/b.baedorf@openproject.com.signature
index 78caad7b..a8a8e333 100644
--- a/users/ben/.config/mutt/b.baedorf@openproject.com.signature
+++ b/users/ben/.config/mutt/b.baedorf@openproject.com.signature
@@ -1,3 +1,4 @@
+--
Benjamin Bädorf
Senior Frontend Engineer
diff --git a/users/ben/.config/mutt/byb@miom.space.signature b/users/ben/.config/mutt/byb@miom.space.signature
index adf5bed3..29f93057 100644
--- a/users/ben/.config/mutt/byb@miom.space.signature
+++ b/users/ben/.config/mutt/byb@miom.space.signature
@@ -1,5 +1,7 @@
-Benjamin Yule Bädorf (they/them)
+--
+
+Benjamin Bädorf (he/him)
Software Engineer at MiOM 202
MAIL: byb@miom.space
diff --git a/users/ben/.config/mutt/crew@pub.solar.muttrc b/users/ben/.config/mutt/crew@pub.solar.muttrc
deleted file mode 100644
index 29d85931..00000000
--- a/users/ben/.config/mutt/crew@pub.solar.muttrc
+++ /dev/null
@@ -1,19 +0,0 @@
-# vim: filetype=muttrc
-
-set from = "pub.solar crew "
-set sendmail = "msmtp -a crew@pub.solar"
-set signature = "~/.config/mutt/crew@pub.solar.signature"
-
-set mbox_type = Maildir
-set folder = ~/Mail
-set spoolfile = "+crew\@pub.solar/INBOX"
-set postponed = "+crew\@pub.solar/Drafts"
-set record = "+crew\@pub.solar/Sent"
-set trash = "+crew\@pub.solar/Trash"
-mbox-hook = "+crew\@pub.solar/Archive"
-unmailboxes *
-mailboxes +crew\@pub.solar/INBOX \
- +crew\@pub.solar/Drafts \
- +crew\@pub.solar/Sent \
- +crew\@pub.solar/Archive \
- +crew\@pub.solar/Trash
diff --git a/users/ben/.config/mutt/crew@pub.solar.signature b/users/ben/.config/mutt/crew@pub.solar.signature
deleted file mode 100644
index 4755ed6a..00000000
--- a/users/ben/.config/mutt/crew@pub.solar.signature
+++ /dev/null
@@ -1,8 +0,0 @@
-
-pub.solar crew (they/them)
-
-MAIL: crew@pub.solar
-MASTODON: @crew@pub.solar
-GIT: git.b12f.io/pub-solar
-MATRIX: #general:pub.solar
-WEB: pub.solar
diff --git a/users/ben/.config/mutt/hello@benjaminbaedorf.eu.signature b/users/ben/.config/mutt/hello@benjaminbaedorf.eu.signature
index 149014c1..d72c2792 100644
--- a/users/ben/.config/mutt/hello@benjaminbaedorf.eu.signature
+++ b/users/ben/.config/mutt/hello@benjaminbaedorf.eu.signature
@@ -1,5 +1,7 @@
-Benjamin Yule Bädorf (they/them)
+--
+
+Benjamin Bädorf (he/him)
Software Engineer
MAIL: hello@benjaminbaedorf.eu
diff --git a/users/ben/.config/mutt/mail@b12f.io.signature b/users/ben/.config/mutt/mail@b12f.io.signature
index b12bc7e9..3e3e37aa 100644
--- a/users/ben/.config/mutt/mail@b12f.io.signature
+++ b/users/ben/.config/mutt/mail@b12f.io.signature
@@ -1,5 +1,7 @@
-Benjamin Yule Bädorf (they/them)
+--
+
+Benjamin Bädorf (he/him)
Software Engineer
MAIL: mail@b12f.io
diff --git a/users/ben/.config/offlineimap/config b/users/ben/.config/offlineimap/config
index 0313206c..d277ebe0 100644
--- a/users/ben/.config/offlineimap/config
+++ b/users/ben/.config/offlineimap/config
@@ -1,7 +1,7 @@
[general]
pythonfile = $XDG_CONFIG_HOME/offlineimap/functions.py
metadata = $XDG_DATA_HOME/offlineimap
-accounts = BBEU, MiOM, AdminsPubSolar, CrewPubSolar, b12f, RWTH
+accounts = BBEU, MiOM, PubSolar, b12f, RWTH
[Account BBEU]
localrepository = LocalBBEU
@@ -48,36 +48,21 @@ remoteuser = byb@miom.space
remotepasseval = get_secret("service", "smtp", "host", "mail.hosting.de", "user", "byb@miom.space")
sslcacertfile = /etc/ssl/certs/ca-certificates.crt
-[Account AdminsPubSolar]
-localrepository = LocalAdminsPubSolar
-remoterepository = RemoteAdminsPubSolar
+[Account PubSolar]
+localrepository = LocalPubSolar
+remoterepository = RemotePubSolar
-[Repository LocalAdminsPubSolar]
+[Repository LocalPubSolar]
type = Maildir
-localfolders = ~/Mail/admins@pub.solar
+localfolders = ~/Mail/byb@miom.space
-[Repository RemoteAdminsPubSolar]
+[Repository RemotePubSolar]
type = IMAP
remotehost = mail.greenbaum.cloud
remoteuser = admins@pub.solar
remotepasseval = get_secret("service", "smtp", "host", "mail.greenbaum.cloud", "user", "admins@pub.solar")
sslcacertfile = /etc/ssl/certs/ca-certificates.crt
-[Account CrewPubSolar]
-localrepository = LocalCrewPubSolar
-remoterepository = RemoteCrewPubSolar
-
-[Repository LocalCrewPubSolar]
-type = Maildir
-localfolders = ~/Mail/crew@pub.solar
-
-[Repository RemoteCrewPubSolar]
-type = IMAP
-remotehost = mail.greenbaum.cloud
-remoteuser = crew@pub.solar
-remotepasseval = get_secret("service", "smtp", "host", "mail.greenbaum.cloud", "user", "crew@pub.solar")
-sslcacertfile = /etc/ssl/certs/ca-certificates.crt
-
[Account b12f]
localrepository = Localb12f
remoterepository = Remoteb12f
diff --git a/users/ben/default.nix b/users/ben/default.nix
index ce609813..106a973e 100644
--- a/users/ben/default.nix
+++ b/users/ben/default.nix
@@ -23,11 +23,12 @@ in
fullName = "Benjamin Bädorf";
email = "hello@benjaminbaedorf.eu";
gpgKeyId = "4406E80E13CD656C";
- publicKeys = [
- "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDDoYNvXWunQYFORRjcYH1F98+zr20U79ROh+gmaC7AY/x3yf4y8uyMayF56VgQLVNwgEchT5t4dNb9qo2+1oUnjiKrKAVfQMN6WMMMEr4F4WT784uvBx5Uo6vmhgAa+xoo62c4TV2Uf49ZiPd+zAApBHW1F/whPtunPF28Wfr9g+ozSidhnAr+3nkfJh331tz9s+wgQ39AFzFWftQ60Guulpfj8SaVyxyv/yZZAuFpXNzN0Cz4fWBIWFOsib6Z8y+SlUCzSzOguZ7FygHjwlvOxoISsASAuf0OfUKHxVshiL5F5AX1ddmUgXbUKUTp/3Iunr74pfOQC8TXzZHqhrlFzYDmK5J9E6eADSpgx++bCCaHycl73BWeertCBZSHBXeb3Db9HX+mxwpfP3alVAt4ZqQb3YD/VB7XGDvHbmLn+wSfecO2qA9PxiA0yX7e2BZLN9r3G3bRNSk0GpnYM0i84FE9IipiKKnWVjj7J0UPQmz7rzAn2Lki1CnX9PDdxZneqTxgpBomHJt4H+vXMw13scA4xxEDBvfS5KkjbEJqWLbfklCoER6nV3NPLZ6CBl0Xe/VQBSkqEuUEIXih/oa8emDOGUODNF75ck5NJmKiGg6AFZoeiDa7PZMIxhhOq4vsR2Ty43rztUJ0CMX7iSIk3Eql7kqNdvrJaJ7z0GBsiw== ben@biolimo"
- "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCmiF8ndGhnx2YAWbPDq14fftAwcJ0xnjJIVTotI12OO4SPX/SwH5Yp8C8Kf002qN9FbFmaONzq3s8TYpej13JubhfsQywNuFKZuZvJeHzmOwxsANW86RVrWT0WZmYx9a/a1TF9rPQpibDVt60wX8yLdExaJc5F1SvIIuyz1kxYpz36wItfR6hcwoLGh1emFCmfCpebJmp3hsrMDTTtTW/YNhyeSZW74ckyvZyjCYtRCJ8uF0ZmOSKRdillv4Ztg8MsUubGn+vaMl6V6x/QuDuehEPoM/3wBx9o22nf+QVbk7S1PC8EdT/K5vskn4/pfR7mDCyQOq1hB4w4Oyn0dsfX pi@ssrtc"
- "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDwyNsGCMuyI9x2IxYEbYIL6oYsEfe1wqhHaRxSnK9oc10ge1LJni5o7g6XgryoQpCD9YenImcCxwkKblmlLQ2327uoVC2PUo07li1uT0eIPk0TQoxwp6besFs7/LEzZlgWQsc3gkEXmjk/E0mu0U6z2fkqciJ/ZxWYt9fLP6jBG47U9878rSaZ7k7Ilv6oRA3suArH189k1nerk/tonS4EWXeHZxHh/Eu0tqwmxN/6+g2GicYn6b+MbFQVdQAkctqT5Yz9USm9UKzbaAuZ799u0dJzagHm9JJZOr8r11ENtAkY9kAzRzm3u/ACiSdVzyLdjAK6m0dIPhp3OhedzuHiI6/wRll60tYtQTH1XwUpVbtir3+DT+jwZgO1zH3yL4iNh79kuUo+UEg1ZmGkSZRzSS2vb5qr0J5aSJmCd5sNB7a01PTtSlQPOqSF9PB+UmcLDF7JoKFub0KT/gRZ5neZkXTYQ/Y05qtaaFVlOVISijnm+sLUvKBv6OW8oYXIHBk= ben@chocolatebar"
- ];
+ #publicKeys = [
+ # "ssh-rsa AAAhAB3NzaC1yc2EAAAADAQABAAACAQCmXpOU6vzQiVSSYCoxHYv7wDxC63Qg3dxlAMR6AOzwIABCU5PFFNcO0NWYms/YR7MOViorl+19LCLRABar9JgHU1n+uqxKV6eGph3OPeMp5sN8LAh7C9N+TZj8iJzBxQ3ch+Z/LdmLRwYNJ7KSUI+gwGK6xRS3+z1022Y4P0G0sx7IeCBl4lealQEIIF10ZOfjUdBcLQar7XTc5AxyGKnHCerXHRtccCoadLQujk0AvPXbv3Ma4JwX9X++AnCWRWakqS5UInu2tGuZ/6Hrjd2a9AKWjTaBVDcbYqCvY4XVuMj2/A2bCceFBaoi41apybSk26FSFTU4qiEUNQ6lxeOwG4+1NCXyHe2bGI4VyoxinDYa8vLLzXIRfTRA0qoGfCweXNeWPf0jMqASkUKaSOH5Ot7O5ps34r0j9pWzavDid8QeKJPyhxKuF1a5G4iBEZ0O9vuti60dPSjJPci9oTxbune2/jb7Sa0yO06DtLFJ2ncr5f70s/BDxKk4XIwQLy+KsvzlQEGdY8yA6xv28bOGxL3sQ0HE2pDTsvIbAisVOKzdJeolStL9MM5W8Hg0r/KkGj2bg0TfoRp1xHV9hjKkvJrsQ6okaPvNFeZq0HXzPhWMOVQ+/46z80uaQ1ByRLr3FTwuWJ7F/73ndfxiq6bDE4z2Ji0vOjeWJm6HCxTdGw== hello@benjaminbaedorf.com"
+ # "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCnYTlTmHCl6LOkexqRR9LqjOoFgt9TQ4VzHQGRHJMzF/AGcDRoqC+pBLFSTzRb5/ikAOsb32XHyKVg4nNdJeQshO11QtDmkCB02D/XcIXxnNQ5A8CztT2az5xJtbbWSdamMnHBLcqLiwoLmXbERpdlt8jNqMHrz+bjCUGYVAFSfc/WdIs6EATJ1eF0VFxv7nUh4qhgStABSwhNsnoYOC/DOBSA9aBP1f5Fz9QHUioPTGi2hRwbTbtFUvTrymPpWVFRApa1zvGXcr4YUCm7ia1ZlZKzRpsPkwLxb8Omm4bGmR0cAVwVhVRySnhpCTwbIBLyw+H8PvKWBBba1NAKyMij root@droppie"
+ # "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDwyNsGCMuyI9x2IxYEbYIL6oYsEfe1wqhHaRxSnK9oc10ge1LJni5o7g6XgryoQpCD9YenImcCxwkKblmlLQ2327uoVC2PUo07li1uT0eIPk0TQoxwp6besFs7/LEzZlgWQsc3gkEXmjk/E0mu0U6z2fkqciJ/ZxWYt9fLP6jBG47U9878rSaZ7k7Ilv6oRA3suArH189k1nerk/tonS4EWXeHZxHh/Eu0tqwmxN/6+g2GicYn6b+MbFQVdQAkctqT5Yz9USm9UKzbaAuZ799u0dJzagHm9JJZOr8r11ENtAkY9kAzRzm3u/ACiSdVzyLdjAK6m0dIPhp3OhedzuHiI6/wRll60tYtQTH1XwUpVbtir3+DT+jwZgO1zH3yL4iNh79kuUo+UEg1ZmGkSZRzSS2vb5qr0J5aSJmCd5sNB7a01PTtSlQPOqSF9PB+UmcLDF7JoKFub0KT/gRZ5neZkXTYQ/Y05qtaaFVlOVISijnm+sLUvKBv6OW8oYXIHBk= ben@chocolatebar"
+ # "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDDoYNvXWunQYFORRjcYH1F98+zr20U79ROh+gmaC7AY/x3yf4y8uyMayF56VgQLVNwgEchT5t4dNb9qo2+1oUnjiKrKAVfQMN6WMMMEr4F4WT784uvBx5Uo6vmhgAa+xoo62c4TV2Uf49ZiPd+zAApBHW1F/whPtunPF28Wfr9g+ozSidhnAr+3nkfJh331tz9s+wgQ39AFzFWftQ60Guulpfj8SaVyxyv/yZZAuFpXNzN0Cz4fWBIWFOsib6Z8y+SlUCzSzOguZ7FygHjwlvOxoISsASAuf0OfUKHxVshiL5F5AX1ddmUgXbUKUTp/3Iunr74pfOQC8TXzZHqhrlFzYDmK5J9E6eADSpgx++bCCaHycl73BWeertCBZSHBXeb3Db9HX+mxwpfP3alVAt4ZqQb3YD/VB7XGDvHbmLn+wSfecO2qA9PxiA0yX7e2BZLN9r3G3bRNSk0GpnYM0i84FE9IipiKKnWVjj7J0UPQmz7rzAn2Lki1CnX9PDdxZneqTxgpBomHJt4H+vXMw13scA4xxEDBvfS5KkjbEJqWLbfklCoER6nV3NPLZ6CBl0Xe/VQBSkqEuUEIXih/oa8emDOGUODNF75ck5NJmKiGg6AFZoeiDa7PZMIxhhOq4vsR2Ty43rztUJ0CMX7iSIk3Eql7kqNdvrJaJ7z0GBsiw== ben@biolimo"
+ #];
};
paperless.enable = true;
@@ -38,22 +39,12 @@ in
audio.spotify.username = "spotify@benjaminbaedorf.eu";
};
- # Needed for the udev rules for solaar
- hardware.logitech.wireless.enable = true;
- networking.hosts =
- let
- localDomains = [
- "openproject.local"
- "traefik.local"
- "nextcloud.local"
- "step.local"
- "saas-1.openproject.local"
- "transmission.local"
- ];
- in
- {
- "127.0.0.1" = localDomains;
- "::1" = localDomains;
- };
+ networking.hosts = {
+ "127.0.0.1" = [
+ "openproject.local"
+ "saas-1.openproject.local"
+ "transmission.local"
+ ];
+ };
};
}
diff --git a/users/ben/home.nix b/users/ben/home.nix
index 1e9388bc..0aff38a7 100644
--- a/users/ben/home.nix
+++ b/users/ben/home.nix
@@ -15,7 +15,6 @@ in
dogecoin
nodejs
itch
- solaar
];
programs.ssh = {
@@ -64,12 +63,6 @@ in
MACs = "hmac-sha2-512-etm@openssh.com";
};
};
-
- "laurakirst.de" = {
- hostname = "webj4bsux.wh.hosting.zone";
- user = "webj4bsux_36qkrk";
- port = 2244;
- };
};
};
@@ -80,9 +73,8 @@ in
macro index 'source $XDG_CONFIG_HOME/mutt/benjamin.baedorf@rwth-aachen.de.muttrc!'
macro index 'source $XDG_CONFIG_HOME/mutt/b.baedorf@openproject.com.muttrc!'
macro index 'source $XDG_CONFIG_HOME/mutt/byb@miom.space.muttrc!'
- macro index 'source $XDG_CONFIG_HOME/mutt/mail@b12f.io.muttrc!'
- macro index 'source $XDG_CONFIG_HOME/mutt/admins@pub.solar.muttrc!'
- macro index 'source $XDG_CONFIG_HOME/mutt/crew@pub.solar.muttrc!'
+ macro index 'source $XDG_CONFIG_HOME/mutt/admins@pub.solar.muttrc!'
+ macro index 'source $XDG_CONFIG_HOME/mutt/mail@b12f.io.muttrc!'
'';
xdg.configFile."mutt/hello@benjaminbaedorf.eu.muttrc".source = ./.config/mutt + "/hello@benjaminbaedorf.eu.muttrc";
xdg.configFile."mutt/benjamin.baedorf@rwth-aachen.de.muttrc".source = ./.config/mutt + "/benjamin.baedorf@rwth-aachen.de.muttrc";
@@ -91,12 +83,10 @@ in
xdg.configFile."mutt/b.baedorf@openproject.com.signature".source = ./.config/mutt + "/b.baedorf@openproject.com.signature";
xdg.configFile."mutt/byb@miom.space.muttrc".source = ./.config/mutt + "/byb@miom.space.muttrc";
xdg.configFile."mutt/byb@miom.space.signature".source = ./.config/mutt + "/byb@miom.space.signature";
- xdg.configFile."mutt/mail@b12f.io.muttrc".source = ./.config/mutt + "/mail@b12f.io.muttrc";
- xdg.configFile."mutt/mail@b12f.io.signature".source = ./.config/mutt + "/mail@b12f.io.signature";
xdg.configFile."mutt/admins@pub.solar.muttrc".source = ./.config/mutt + "/admins@pub.solar.muttrc";
xdg.configFile."mutt/admins@pub.solar.signature".source = ./.config/mutt + "/admins@pub.solar.signature";
- xdg.configFile."mutt/crew@pub.solar.muttrc".source = ./.config/mutt + "/crew@pub.solar.muttrc";
- xdg.configFile."mutt/crew@pub.solar.signature".source = ./.config/mutt + "/crew@pub.solar.signature";
+ xdg.configFile."mutt/mail@b12f.io.muttrc".source = ./.config/mutt + "/mail@b12f.io.muttrc";
+ xdg.configFile."mutt/mail@b12f.io.signature".source = ./.config/mutt + "/mail@b12f.io.signature";
xdg.configFile."offlineimap/config".source = ./.config/offlineimap/config;
xdg.configFile."msmtp/config".source = ./.config/msmtp/config;
# xdg.configFile."wallpaper.jpg".source = ./assets/wallpaper.jpg;
@@ -107,7 +97,7 @@ in
mode = "700";
owner = "mopidy";
};
- services.mopidy.extraConfigFiles = [ "/run/agenix/mopidy.conf" ];
+ services.mopidy.extraConfigFiles = [ "/run/secrets/mopidy.conf" ];
programs.ssh.extraConfig = "
PubkeyAcceptedKeyTypes +ssh-rsa
diff --git a/users/yule/default.nix b/users/yule/default.nix
index 960f85b3..7f57a686 100644
--- a/users/yule/default.nix
+++ b/users/yule/default.nix
@@ -13,21 +13,15 @@ in
user = {
name = "yule";
description = "b12f";
- password = "$6$pHMaL9DfxhvnLGy5$ka9bRU5p1lPTF0YHPZDM9Miq79iXuaXb6GLeALM1eX5djdsHYnpvVWjrmImWmcghGXsrDwpmXZPSJUU.gFpuA1";
+ password = "$6$LO2YoaHwuRQhUoSz$iHw9avM887eJg9cIty2nmG4Ibkol3YpviEhYpivVQP31VrnihFz/6LyugxD7X4VmXx9nxvcYIZnN90rlGxwjT.";
fullName = "Benjamin Bädorf";
email = "hello@benjaminbaedorf.eu";
gpgKeyId = "4406E80E13CD656C";
publicKeys = [
- "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCmiF8ndGhnx2YAWbPDq14fftAwcJ0xnjJIVTotI12OO4SPX/SwH5Yp8C8Kf002qN9FbFmaONzq3s8TYpej13JubhfsQywNuFKZuZvJeHzmOwxsANW86RVrWT0WZmYx9a/a1TF9rPQpibDVt60wX8yLdExaJc5F1SvIIuyz1kxYpz36wItfR6hcwoLGh1emFCmfCpebJmp3hsrMDTTtTW/YNhyeSZW74ckyvZyjCYtRCJ8uF0ZmOSKRdillv4Ztg8MsUubGn+vaMl6V6x/QuDuehEPoM/3wBx9o22nf+QVbk7S1PC8EdT/K5vskn4/pfR7mDCyQOq1hB4w4Oyn0dsfX pi@ssrtc"
-
- "ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBHx4A8rLYmFgTOp1fDGbbONN8SOT0l5wWrUSYFUcVzMPTyfdT23ZVIdVD5yZCySgi/7PSh5mVmyLIZVIXlNrZJg= @b12f Yubi Main"
- "ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBEST9eyAY3nzGYNnqDYfWHu+89LZsOjyKHMqCFvtP7vrgB7F7JbbECjdjAXEOfPDSCVwtMMpq8JJXeRMjpsD0rw= @b12f Yubi Backup"
-
- "ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBFro/k4Mgqyh8yV/7Zwjc0dv60ZM7bROBU9JNd99P/4co6fxPt1pJiU/pEz2Dax/HODxgcO+jFZfvPEuLMCeAl0= YubiKey #10593996 PIV Slot 9a @teutat3s"
- "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAII/58A18EtxnLYHu63c/+AyTSkJQSso/VVdHUFGp1CTk cardno:FFFE34353135 @hensoko"
- "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIAqkqMYgncrnczcW/0PY+Z+FmNXXpgw6D9JWTTwiainy hensoko@hensoko-tp-work"
-
- "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIIKa5elEXgBc2luVBOHVWZisJgt0epFQOercPi0tZzPU root@cloud.pub.solar"
+ "ssh-rsa AAAhAB3NzaC1yc2EAAAADAQABAAACAQCmXpOU6vzQiVSSYCoxHYv7wDxC63Qg3dxlAMR6AOzwIABCU5PFFNcO0NWYms/YR7MOViorl+19LCLRABar9JgHU1n+uqxKV6eGph3OPeMp5sN8LAh7C9N+TZj8iJzBxQ3ch+Z/LdmLRwYNJ7KSUI+gwGK6xRS3+z1022Y4P0G0sx7IeCBl4lealQEIIF10ZOfjUdBcLQar7XTc5AxyGKnHCerXHRtccCoadLQujk0AvPXbv3Ma4JwX9X++AnCWRWakqS5UInu2tGuZ/6Hrjd2a9AKWjTaBVDcbYqCvY4XVuMj2/A2bCceFBaoi41apybSk26FSFTU4qiEUNQ6lxeOwG4+1NCXyHe2bGI4VyoxinDYa8vLLzXIRfTRA0qoGfCweXNeWPf0jMqASkUKaSOH5Ot7O5ps34r0j9pWzavDid8QeKJPyhxKuF1a5G4iBEZ0O9vuti60dPSjJPci9oTxbune2/jb7Sa0yO06DtLFJ2ncr5f70s/BDxKk4XIwQLy+KsvzlQEGdY8yA6xv28bOGxL3sQ0HE2pDTsvIbAisVOKzdJeolStL9MM5W8Hg0r/KkGj2bg0TfoRp1xHV9hjKkvJrsQ6okaPvNFeZq0HXzPhWMOVQ+/46z80uaQ1ByRLr3FTwuWJ7F/73ndfxiq6bDE4z2Ji0vOjeWJm6HCxTdGw== hello@benjaminbaedorf.com"
+ "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCnYTlTmHCl6LOkexqRR9LqjOoFgt9TQ4VzHQGRHJMzF/AGcDRoqC+pBLFSTzRb5/ikAOsb32XHyKVg4nNdJeQshO11QtDmkCB02D/XcIXxnNQ5A8CztT2az5xJtbbWSdamMnHBLcqLiwoLmXbERpdlt8jNqMHrz+bjCUGYVAFSfc/WdIs6EATJ1eF0VFxv7nUh4qhgStABSwhNsnoYOC/DOBSA9aBP1f5Fz9QHUioPTGi2hRwbTbtFUvTrymPpWVFRApa1zvGXcr4YUCm7ia1ZlZKzRpsPkwLxb8Omm4bGmR0cAVwVhVRySnhpCTwbIBLyw+H8PvKWBBba1NAKyMij root@droppie"
+ "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDwyNsGCMuyI9x2IxYEbYIL6oYsEfe1wqhHaRxSnK9oc10ge1LJni5o7g6XgryoQpCD9YenImcCxwkKblmlLQ2327uoVC2PUo07li1uT0eIPk0TQoxwp6besFs7/LEzZlgWQsc3gkEXmjk/E0mu0U6z2fkqciJ/ZxWYt9fLP6jBG47U9878rSaZ7k7Ilv6oRA3suArH189k1nerk/tonS4EWXeHZxHh/Eu0tqwmxN/6+g2GicYn6b+MbFQVdQAkctqT5Yz9USm9UKzbaAuZ799u0dJzagHm9JJZOr8r11ENtAkY9kAzRzm3u/ACiSdVzyLdjAK6m0dIPhp3OhedzuHiI6/wRll60tYtQTH1XwUpVbtir3+DT+jwZgO1zH3yL4iNh79kuUo+UEg1ZmGkSZRzSS2vb5qr0J5aSJmCd5sNB7a01PTtSlQPOqSF9PB+UmcLDF7JoKFub0KT/gRZ5neZkXTYQ/Y05qtaaFVlOVISijnm+sLUvKBv6OW8oYXIHBk= ben@chocolatebar"
+ "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDDoYNvXWunQYFORRjcYH1F98+zr20U79ROh+gmaC7AY/x3yf4y8uyMayF56VgQLVNwgEchT5t4dNb9qo2+1oUnjiKrKAVfQMN6WMMMEr4F4WT784uvBx5Uo6vmhgAa+xoo62c4TV2Uf49ZiPd+zAApBHW1F/whPtunPF28Wfr9g+ozSidhnAr+3nkfJh331tz9s+wgQ39AFzFWftQ60Guulpfj8SaVyxyv/yZZAuFpXNzN0Cz4fWBIWFOsib6Z8y+SlUCzSzOguZ7FygHjwlvOxoISsASAuf0OfUKHxVshiL5F5AX1ddmUgXbUKUTp/3Iunr74pfOQC8TXzZHqhrlFzYDmK5J9E6eADSpgx++bCCaHycl73BWeertCBZSHBXeb3Db9HX+mxwpfP3alVAt4ZqQb3YD/VB7XGDvHbmLn+wSfecO2qA9PxiA0yX7e2BZLN9r3G3bRNSk0GpnYM0i84FE9IipiKKnWVjj7J0UPQmz7rzAn2Lki1CnX9PDdxZneqTxgpBomHJt4H+vXMw13scA4xxEDBvfS5KkjbEJqWLbfklCoER6nV3NPLZ6CBl0Xe/VQBSkqEuUEIXih/oa8emDOGUODNF75ck5NJmKiGg6AFZoeiDa7PZMIxhhOq4vsR2Ty43rztUJ0CMX7iSIk3Eql7kqNdvrJaJ7z0GBsiw== ben@biolimo"
];
};
};