mirror of
https://github.com/NixOS/mobile-nixos.git
synced 2024-12-26 09:26:14 +03:00
examples/demo: inits a demo configuration for a system
This commit is contained in:
parent
e318e1603f
commit
e8e3b46207
107
examples/demo/configuration.nix
Normal file
107
examples/demo/configuration.nix
Normal file
@ -0,0 +1,107 @@
|
|||||||
|
{ config, lib, pkgs, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
inherit (lib) mkForce;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
imports = [
|
||||||
|
../../profiles/installer.nix
|
||||||
|
];
|
||||||
|
disabledModules = [
|
||||||
|
<nixpkgs/nixos/modules/installer/cd-dvd/iso-image.nix>
|
||||||
|
<nixpkgs/nixos/modules/installer/cd-dvd/installation-cd-base.nix>
|
||||||
|
];
|
||||||
|
|
||||||
|
config = lib.mkMerge [
|
||||||
|
{
|
||||||
|
|
||||||
|
services.xserver = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
libinput.enable = true;
|
||||||
|
videoDrivers = [ "fbdev" ];
|
||||||
|
|
||||||
|
# xfce has been chosen mainly because it is light, and quick to start.
|
||||||
|
# FIXME: Find a better demo environment.
|
||||||
|
desktopManager.xfce.enable = true;
|
||||||
|
|
||||||
|
# Automatically login as nixos.
|
||||||
|
displayManager.slim = {
|
||||||
|
enable = true;
|
||||||
|
defaultUser = "nixos";
|
||||||
|
autoLogin = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
powerManagement.enable = true;
|
||||||
|
hardware.pulseaudio.enable = true;
|
||||||
|
|
||||||
|
environment.systemPackages = with pkgs; [
|
||||||
|
firefox
|
||||||
|
sgtpuzzles
|
||||||
|
hard-reboot
|
||||||
|
hard-shutdown
|
||||||
|
];
|
||||||
|
|
||||||
|
# Hacky way to setup an initial brightness
|
||||||
|
# TODO: better factor this out...
|
||||||
|
mobile.boot.stage-1.initFramebuffer = ''
|
||||||
|
brightness=10
|
||||||
|
echo "Setting brightness to $brightness"
|
||||||
|
if [ -e /sys/class/backlight/backlight/brightness ]; then
|
||||||
|
echo $(($(cat /sys/class/backlight/backlight/max_brightness) * brightness / 100)) > /sys/class/backlight/backlight/brightness
|
||||||
|
elif [ -e /sys/class/leds/lcd-backlight/max_brightness ]; then
|
||||||
|
echo $(($(cat /sys/class/leds/lcd-backlight/max_brightness) * brightness / 100)) > /sys/class/leds/lcd-backlight/brightness
|
||||||
|
elif [ -e /sys/class/leds/lcd-backlight/brightness ]; then
|
||||||
|
# Assumes max brightness is 100... probably wrong, but good enough, eh.
|
||||||
|
echo $brightness > /sys/class/leds/lcd-backlight/brightness
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
|
||||||
|
# Puts some icons on the desktop.
|
||||||
|
system.activationScripts.fillDesktop = let
|
||||||
|
minesDesktopFile = pkgs.writeScript "mines.desktop" ''
|
||||||
|
[Desktop Entry]
|
||||||
|
Version=1.0
|
||||||
|
Type=Application
|
||||||
|
Name=Mines
|
||||||
|
Exec=${pkgs.sgtpuzzles}/bin/sgt-puzzle-mines
|
||||||
|
'';
|
||||||
|
|
||||||
|
homeDir = "/home/nixos/";
|
||||||
|
desktopDir = homeDir + "Desktop/";
|
||||||
|
|
||||||
|
in ''
|
||||||
|
mkdir -p ${desktopDir}
|
||||||
|
chown nixos ${homeDir} ${desktopDir}
|
||||||
|
|
||||||
|
ln -sfT ${minesDesktopFile} ${desktopDir + "mines.desktop"}
|
||||||
|
'';
|
||||||
|
|
||||||
|
# FIXME : Stop relying on initrd for `ssh` via USB.
|
||||||
|
networking.networkmanager.enable = true;
|
||||||
|
networking.networkmanager.unmanaged = [ "rndis0" "usb0" ];
|
||||||
|
|
||||||
|
# Setup USB gadget networking in initrd...
|
||||||
|
mobile.boot.stage-1.networking.enable = true;
|
||||||
|
#mobile.boot.stage-1.ssh.enable = true;
|
||||||
|
|
||||||
|
# Start SSH by default...
|
||||||
|
systemd.services.sshd.wantedBy = lib.mkOverride 10 [ "multi-user.target" ];
|
||||||
|
services.openssh.permitRootLogin = lib.mkForce "yes";
|
||||||
|
|
||||||
|
# Forcibly set a password on users...
|
||||||
|
# FIXME: highly insecure!
|
||||||
|
# FIXME: Figure out why this breaks...
|
||||||
|
#services.openssh.extraConfig = "PermitEmptyPasswords yes";
|
||||||
|
users.users.nixos.password = "nixos";
|
||||||
|
users.users.root.password = "nixos";
|
||||||
|
|
||||||
|
# Okay, systemd-udev-settle times out... no idea why yet...
|
||||||
|
# Though, it seems fine to simply disable it.
|
||||||
|
# FIXME : figure out why systemd-udev-settle doesn't work.
|
||||||
|
systemd.services.systemd-udev-settle.enable = false;
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
@ -1,10 +1,15 @@
|
|||||||
{ device ? null }:
|
{ device ? null }:
|
||||||
let
|
let
|
||||||
|
system-build = import ../../. {
|
||||||
|
inherit device;
|
||||||
|
configuration = [ (import ./configuration.nix) ];
|
||||||
|
};
|
||||||
burn-tool-build = import ../../. {
|
burn-tool-build = import ../../. {
|
||||||
inherit device;
|
inherit device;
|
||||||
configuration = [ (import ./android-burn-tool.nix) ];
|
configuration = [ (import ./android-burn-tool.nix) ];
|
||||||
};
|
};
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
inherit (system-build.build) android-bootimg android-device;
|
||||||
android-burn-tool = burn-tool-build.build.android-bootimg;
|
android-burn-tool = burn-tool-build.build.android-bootimg;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user