it work now
This commit is contained in:
17
flake.lock
generated
17
flake.lock
generated
@@ -1,5 +1,21 @@
|
|||||||
{
|
{
|
||||||
"nodes": {
|
"nodes": {
|
||||||
|
"flake-utils": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1652776076,
|
||||||
|
"narHash": "sha256-gzTw/v1vj4dOVbpBSJX4J0DwUR6LIyXo7/SuuTJp1kM=",
|
||||||
|
"owner": "numtide",
|
||||||
|
"repo": "flake-utils",
|
||||||
|
"rev": "04c1b180862888302ddfb2e3ad9eaa63afc60cf8",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "numtide",
|
||||||
|
"ref": "v1.0.0",
|
||||||
|
"repo": "flake-utils",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1764521362,
|
"lastModified": 1764521362,
|
||||||
@@ -18,6 +34,7 @@
|
|||||||
},
|
},
|
||||||
"root": {
|
"root": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
|
"flake-utils": "flake-utils",
|
||||||
"nixpkgs": "nixpkgs"
|
"nixpkgs": "nixpkgs"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
48
flake.nix
48
flake.nix
@@ -1,31 +1,40 @@
|
|||||||
{ inputs = {
|
{
|
||||||
|
inputs = {
|
||||||
flake-utils.url = "github:numtide/flake-utils/v1.0.0";
|
flake-utils.url = "github:numtide/flake-utils/v1.0.0";
|
||||||
|
|
||||||
nixpkgs.url = "github:NixOS/nixpkgs/25.11";
|
nixpkgs.url = "github:NixOS/nixpkgs/25.11";
|
||||||
};
|
};
|
||||||
|
|
||||||
outputs = { flake-utils, nixpkgs, ... }:
|
outputs =
|
||||||
flake-utils.lib.eachDefaultSystem (system:
|
{ flake-utils, nixpkgs, ... }:
|
||||||
|
flake-utils.lib.eachDefaultSystem (
|
||||||
|
system:
|
||||||
let
|
let
|
||||||
pkgs = nixpkgs.legacyPackages."${system}";
|
pkgs = nixpkgs.legacyPackages."${system}";
|
||||||
|
modulesPath = "${pkgs.path}/nixos/modules";
|
||||||
|
|
||||||
base = { lib, modulesPath, ... }: {
|
base =
|
||||||
imports = [ "${modulesPath}/virtualisation/qemu-vm.nix" ];
|
{ lib, modulesPath, ... }:
|
||||||
|
{
|
||||||
|
imports = [ "${modulesPath}/virtualisation/qemu-vm.nix" ];
|
||||||
|
|
||||||
# https://github.com/utmapp/UTM/issues/2353
|
# https://github.com/utmapp/UTM/issues/2353
|
||||||
networking.nameservers = lib.mkIf pkgs.stdenv.isDarwin [ "8.8.8.8" ];
|
networking.nameservers = lib.mkIf pkgs.stdenv.isDarwin [ "8.8.8.8" ];
|
||||||
|
|
||||||
virtualisation = {
|
virtualisation = {
|
||||||
graphics = false;
|
graphics = false;
|
||||||
|
|
||||||
host = { inherit pkgs; };
|
host = { inherit pkgs; };
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
|
||||||
|
|
||||||
machine = nixpkgs.lib.nixosSystem {
|
machine = nixpkgs.lib.nixosSystem {
|
||||||
system = builtins.replaceStrings [ "darwin" ] [ "linux" ] system;
|
system = builtins.replaceStrings [ "darwin" ] [ "linux" ] system;
|
||||||
|
|
||||||
modules = [ base ./module.nix ];
|
modules = [
|
||||||
|
base
|
||||||
|
./module.nix
|
||||||
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
program = pkgs.writeShellScript "run-vm.sh" ''
|
program = pkgs.writeShellScript "run-vm.sh" ''
|
||||||
@@ -37,13 +46,16 @@
|
|||||||
'';
|
'';
|
||||||
|
|
||||||
in
|
in
|
||||||
{ packages = { inherit machine; };
|
{
|
||||||
|
packages = { inherit (machine.config.system.build) vm; };
|
||||||
|
|
||||||
apps.default = {
|
defaultPackage = machine.config.system.build.vm;
|
||||||
type = "app";
|
|
||||||
|
|
||||||
program = "${program}";
|
apps.default = {
|
||||||
};
|
type = "app";
|
||||||
}
|
|
||||||
|
program = "${program}";
|
||||||
|
};
|
||||||
|
}
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
48
module.nix
48
module.nix
@@ -5,39 +5,21 @@
|
|||||||
modulesPath,
|
modulesPath,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
|
||||||
asteriskDir = ./asterisk;
|
|
||||||
asteriskFilesRaw = builtins.readDir asteriskDir;
|
|
||||||
asteriskFileNames = builtins.attrNames asteriskFilesRaw;
|
|
||||||
filteredFileNames = builtins.filter (n: n != "asterisk.conf") asteriskFileNames;
|
|
||||||
asteriskFiles = builtins.listToAttrs (
|
|
||||||
builtins.map (n: {
|
|
||||||
name = n;
|
|
||||||
value = builtins.readFile (asteriskDir + "/${n}");
|
|
||||||
}) filteredFileNames
|
|
||||||
);
|
|
||||||
in
|
|
||||||
{
|
{
|
||||||
imports = [
|
services.getty.autologinUser = "root";
|
||||||
"${modulesPath}/services/networking/asterisk.nix"
|
services.asterisk.enable = true;
|
||||||
|
services.asterisk.extraConfig = builtins.readFile ./asterisk/asterisk.conf;
|
||||||
|
services.asterisk.confFiles = builtins.listToAttrs (
|
||||||
|
builtins.map (name: {
|
||||||
|
name = name;
|
||||||
|
value = builtins.readFile (./asterisk + "/${name}");
|
||||||
|
}) (builtins.filter (n: n != "asterisk.conf") (builtins.attrNames (builtins.readDir ./asterisk)))
|
||||||
|
);
|
||||||
|
networking.firewall.allowedTCPPorts = [ 5060 ];
|
||||||
|
networking.firewall.allowedUDPPorts = [
|
||||||
|
5060
|
||||||
|
4569
|
||||||
];
|
];
|
||||||
|
boot.kernelParams = [ "console=ttyS0" ];
|
||||||
config = {
|
system.stateVersion = "25.11";
|
||||||
system.stateVersion = "25.11";
|
|
||||||
|
|
||||||
services.asterisk.enable = true;
|
|
||||||
|
|
||||||
services.asterisk.extraConfig = builtins.readFile (asteriskDir + "/asterisk.conf");
|
|
||||||
|
|
||||||
services.asterisk.confFiles = asteriskFiles;
|
|
||||||
|
|
||||||
services.getty.autologinUser = "root";
|
|
||||||
|
|
||||||
networking.firewall.allowedTCPPorts = [ 5060 ];
|
|
||||||
networking.firewall.allowedUDPPorts = [
|
|
||||||
5060
|
|
||||||
4569
|
|
||||||
];
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user