In vhost.nix I want to add the users in a loop like the working example in httpd.virtualHosts.
This is the configuration.nix I am using in a virtual machine:
vm.nix
{ lib, config, ... }:
{
imports = [
./vhosts.nix
];
services.httpd.enable = true;
vhosts = {
"test.example.de" = {
customer = "web2";
phpuser = "web2www1";
};
"test2.example.de" = {
customer = "web3";
phpuser = "web3www1";
};
};
}
this my module vhost.nix
{ config, pkgs, lib, ... }:
with lib;
let
cfg = config.vhosts;
in
{
options.vhosts = lib.mkOption {
type = with lib.types; attrsOf (submodule ({domain, ... }: {
options = {
customer = mkOption {
type = str;
};
phpuser = mkOption {
type = str;
};
};
}));
};
config = {
services.httpd.virtualHosts = lib.mapAttrs (domain: cfg: {
documentRoot = "/srv/www/${cfg.customer}/${domain}";
}) cfg;
how do I solve this in a loop like above ?
users.users.web2www1.isNormalUser = true;
users.users.web3www1.isNormalUser = true;
};
}
how do I solve this in a loop like above ?
Published Date: 2023-11-29T08:06:37Z
I'm trying to enable allow "unfree" packages, either globally or per-package, when using MyNixOS (excellent Flake configuration app for Nix) with Nix Flakes on Mac OS.
When trying to install any unfree package after the following Flake update and Darwin rebuild command:
cd ~/.nix/mynixos-nix-darwin-loader;
nix flake update;
darwin-rebuild switch --show-trace --flake .#name_of_my_config'
I get the following help message, which isn't very helpful because it doesn't consider the Flake scenario:
error: Package ‘ec2-api-tools-1.7.5.1’ in /nix/store/${hash}-source/pkgs/tools/virtualization/e
c2-api-tools/default.nix:36 has an unfree license (‘amazonsl’), refusing to evaluate.
a) To temporarily allow unfree packages, you can use an environment variable
for a single invocation of the nix tools.
$ export NIXPKGS_ALLOW_UNFREE=1
Note: For
nix shell
,nix build
,nix develop
or any other Nix 2.4+(Flake) command,
--impure
must be passed in order to read thisenvironment variable.
b) For
nixos-rebuild
you can set{ nixpkgs.config.allowUnfree = true; }
in configuration.nix to override this.
Alternatively you can configure a predicate to allow specific packages:
{ nixpkgs.config.allowUnfreePredicate = pkg: builtins.elem (lib.getName pkg) [
"ec2-api-tools"
];
}
c) For
nix-env
,nix-build
,nix-shell
or any other Nix command you can add{ allowUnfree = true; }
to ~/.config/nixpkgs/config.nix.
Using MyNixOS downloads the following Flake file, and
/nix/store/${hash}-source/homeConfigurations/my_flake_name.nix :
{ inputs, ... }@flakeContext:
let
homeModule = { config, lib, pkgs, ... }: {
config = {
home = {
packages = [
ec2-api-tools
... more packages
];
stateVersion = "23.11";
};
nixpkgs = {
config = {
allowUnfree = true;
allowUnfreePredicate = (_: true);
allowUnfreePredicate = pkg: builtins.elem (lib.getName pkg) [
"ec2-api-tools"
];
};
};
Which results in a configuration path for the allowUnfreePredicate setting: homeModule.config.nixpkgs.config.allowUnfreePredicate . Does that seem correct?
This configuration seems to make no difference, and installing unfree packages always results in the same error.
Exactly what needs to be done to allow unfree packages in each of these distinct scenarios?
NixOS
Nix
Nix with Flakes
Nix with Flakes and Home Manager
(Please edit the list or let me know if it doesn't make sense)
The advice from the following web pages didn't seem to apply, or I couldn't figure out how to apply it:
NixOS Discourse: Allow unfree in flakes
GitHub: nix-community/home-manager: #2942: bug: Flake config cannot use unfree packages despite nixpkgs.config.allowUnfree = true
GitHub: nix-community/home-manager: #2720: modules/default.nix: Add useNixpkgsModule parameter
Abandoned merge request
Published Date: 2023-12-01T12:21:17Z
Link: https://stackoverflow.com/questions/77635748/how-to-override-packages-in-a-nix-derivation
While developing a nix package, my default.nix looks like this:
let
pkgs = import <nixpkgs> {
config = { ... }
}
in pkgs.path.to.derivation
But when turning that into an actual package, the pkgs comes in as an argument. But adding a config to that doesn't seem to work:
{ pkgs, ... }:
let
pkgs_ = pkgs // { config = { ... } };
in pkgs_.path.to.derivation
How do I add the same config to an already existing package set?
Published Date: 2023-12-10T17:30:37Z
Link: https://stackoverflow.com/questions/77637908/how-to-setup-zsh-users-antigen-with-nix-env-non-nixos
I installed antigen with nix-env -iA nixpkgs.antigen . After that, I have to source the antigen.zsh file into .zshrc but how do I get this file path from nix? Note that I am using macOS with nix-env . One way that I found is to get it from .nix-profile/shared/antigen/antigen.zsh but is it the best way to do it; if so, does it have any cons? Also, is there a $(brew --prefix) version for nix?
Published Date: 2023-12-11T06:58:55Z
I basically want to create my own simple version of mkShell , so now I'm trying to understand how it would even be possible to execute some code before the shell actually pops up. I googled for a bit, and came up with this:
let pkgs = import <nixpkgs> {}; in
derivation {
name = "hello";
shellHook = ''
echo "hello world!"
'';
system = builtins.currentSystem;
builder = "${pkgs.bash}/bin/bash";
args = [ ./setup.sh ];
}
From nix-shell documentation:
If the derivation defines the variable shellHook, it will be run after $stdenv/setup has been sourced. Since this hook is not executed by regular Nix builds, it allows you to perform initialisation specific to nix-shell. For example, the derivation attribute
shellHook =
''
echo "Hello shell"
export SOME_API_TOKEN="$(cat ~/.config/some-app/api-token)"
'';
But that doesn't output anything, although if I replace derivation {} with pkgs.mkShell {} , then it does. How can I make this behaviour work without actually using pkgs.mkShell ?
Published Date: 2023-12-13T22:25:51Z
My flake.nix in /etc/nixos directory:
{
description = "A very basic flake";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-23.11";
home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = { self, nixpkgs, home-manager, ... }@inputs:
let
system = "x86_64-linux";
pkgs = import nixpkgs {
inherit system;
config.allowUnfree = true;
};
in {
nixosConfigurations = rec {
default = nixpkgs.lib.nixosSystem {
specialArgs = { inherit inputs system; };
modules = [ ./configuration.nix home-manager.nixosModules.home-manager ];
};
nixos = default;
};
};
}
When I run it (installing home-manager for the first time), I get this log:
warning: creating lock file '/etc/nixos/flake.lock'
building the system configuration...
trace: warning: monkpatch profile: You are using
Home Manager version 24.05 and
Nixpkgs version 23.11.
Using mismatched versions is likely to cause errors and unexpected
behavior. It is therefore highly recommended to use a release of Home
Manager that corresponds with your chosen release of Nixpkgs.
If you insist then you can disable this warning by adding
home.enableNixpkgsReleaseCheck = false;
to your configuration.
And if I replace nixos-23.11 with nixos-unstable in nixpkgs.url (line 5), then the error disappears. But what if I want to use nixos-23.11 ? What do I do?
Published Date: 2023-12-14T15:58:41Z
I have a project that includes Python packages from a custom PyPi. How can I write a Nix shell.nix to use those packages, alongside others which are in the standard PyPi?
Published Date: 2023-12-14T19:11:11Z
Link: https://stackoverflow.com/questions/77685716/how-can-i-change-group-of-dev-usb-on-nixos
I can't seem to change the group of /dev/usb on nixos. It remains root no matter what I try. I can change the mode though and that has an effect. Here is my configuration for this.
Configuration.nix:
services.udev.extraRules = ''
SUBSYSTEMS=="usb", MODE="0660", GROUP="plugdev" # Not working
SUBSYSTEM=="usb", MODE="0666" # Tested and has an effect
'';
users.groups.plugdev.members = [ "mcmah309" ];
cat /etc/group shows plugdev is created and my user is assigned.
ls -l /dev is still showing usb is in the root group.
I expect the group of /dev/usb to be plugdev .
Published Date: 2023-12-19T13:58:03Z
Last updated: Jan 18 2025 at 04:45 UTC