Merge pull request #44573 from vincentbernat/feature/cloudstack
nixos/cloudstack-image: initial import
This commit is contained in:
commit
d14f102334
2 changed files with 63 additions and 0 deletions
23
nixos/maintainers/scripts/cloudstack/cloudstack-image.nix
Normal file
23
nixos/maintainers/scripts/cloudstack/cloudstack-image.nix
Normal file
|
@ -0,0 +1,23 @@
|
|||
# nix-build '<nixpkgs/nixos>' -A config.system.build.cloudstackImage --arg configuration "{ imports = [ ./nixos/maintainers/scripts/cloudstack/cloudstack-image.nix ]; }"
|
||||
|
||||
{ config, lib, pkgs, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
{
|
||||
imports =
|
||||
[ ../../../modules/virtualisation/cloudstack-config.nix ];
|
||||
|
||||
system.build.cloudstackImage = import ../../../lib/make-disk-image.nix {
|
||||
inherit lib config pkgs;
|
||||
diskSize = 8192;
|
||||
format = "qcow2";
|
||||
configFile = pkgs.writeText "configuration.nix"
|
||||
''
|
||||
{
|
||||
imports = [ <nixpkgs/nixos/modules/virtualisation/cloudstack-config.nix> ];
|
||||
}
|
||||
'';
|
||||
};
|
||||
|
||||
}
|
40
nixos/modules/virtualisation/cloudstack-config.nix
Normal file
40
nixos/modules/virtualisation/cloudstack-config.nix
Normal file
|
@ -0,0 +1,40 @@
|
|||
{ config, lib, pkgs, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
{
|
||||
imports = [
|
||||
../profiles/qemu-guest.nix
|
||||
];
|
||||
|
||||
config = {
|
||||
fileSystems."/" = {
|
||||
device = "/dev/disk/by-label/nixos";
|
||||
autoResize = true;
|
||||
};
|
||||
|
||||
boot.growPartition = true;
|
||||
boot.kernelParams = [ "console=tty0" ];
|
||||
boot.loader.grub.device = "/dev/vda";
|
||||
boot.loader.timeout = 0;
|
||||
|
||||
# Allow root logins
|
||||
services.openssh = {
|
||||
enable = true;
|
||||
permitRootLogin = "prohibit-password";
|
||||
};
|
||||
|
||||
# Cloud-init configuration.
|
||||
services.cloud-init.enable = true;
|
||||
# Wget is needed for setting password. This is of little use as
|
||||
# root password login is disabled above.
|
||||
environment.systemPackages = [ pkgs.wget ];
|
||||
# Only enable CloudStack datasource for faster boot speed.
|
||||
environment.etc."cloud/cloud.cfg.d/99_cloudstack.cfg".text = ''
|
||||
datasource:
|
||||
CloudStack: {}
|
||||
None: {}
|
||||
datasource_list: ["CloudStack"]
|
||||
'';
|
||||
};
|
||||
}
|
Loading…
Reference in a new issue