mirror of
https://github.com/nix-community/nix-on-droid.git
synced 2025-11-08 19:46:07 +01:00
80 lines
3 KiB
Nix
80 lines
3 KiB
Nix
# Copyright (c) 2019-2020, see AUTHORS. Licensed under MIT License, see LICENSE.
|
|
|
|
{ config, lib, customPkgs, writeText }:
|
|
|
|
let
|
|
inherit (customPkgs.packageInfo) cacert coreutils nix;
|
|
in
|
|
|
|
writeText "login-inner" ''
|
|
# This file is generated by nix-on-droid. DO NOT EDIT.
|
|
|
|
set -eu -o pipefail
|
|
|
|
if [ "$#" -eq 0 ]; then # if script is called from within nix-on-droid app
|
|
echo "Welcome to Nix-on-Droid!"
|
|
echo "If nothing works, open an issue at https://github.com/t184256/nix-on-droid/issues or try the rescue shell."
|
|
fi
|
|
|
|
${lib.optionalString config.build.initialBuild ''
|
|
if [ -e /etc/UNINTIALISED ]; then
|
|
export HOME="${config.user.home}"
|
|
export USER="${config.user.userName}"
|
|
|
|
# To prevent gc warnings of nix, see https://github.com/NixOS/nix/issues/3237
|
|
export GC_NPROCS=1
|
|
|
|
echo "Setting default user profile..."
|
|
${nix}/bin/nix-env --switch-profile /nix/var/nix/profiles/per-user/$USER/profile
|
|
|
|
[ "$#" -gt 0 ] || echo "Sourcing Nix environment..."
|
|
. ${nix}/etc/profile.d/nix.sh
|
|
|
|
export NIX_SSL_CERT_FILE=${cacert}
|
|
|
|
echo "Installing and updating nix-channels..."
|
|
${nix}/bin/nix-channel --add ${config.build.channel.nixpkgs} nixpkgs
|
|
${nix}/bin/nix-channel --update nixpkgs
|
|
${nix}/bin/nix-channel --add ${config.build.channel.nix-on-droid} nix-on-droid
|
|
${nix}/bin/nix-channel --update nix-on-droid
|
|
|
|
echo "Copying default nix-on-droid config..."
|
|
${coreutils}/bin/mkdir --parents $HOME/.config/nixpkgs
|
|
${coreutils}/bin/cp $(${nix}/bin/nix-instantiate --eval --expr "<nix-on-droid/modules/environment/login/nix-on-droid.nix.default>") $HOME/.config/nixpkgs/nix-on-droid.nix
|
|
${coreutils}/bin/chmod u+w $HOME/.config/nixpkgs/nix-on-droid.nix
|
|
|
|
echo "Installing first nix-on-droid generation..."
|
|
${nix}/bin/nix build --no-link --file "<nix-on-droid>" nix-on-droid
|
|
$(${nix}/bin/nix path-info --file "<nix-on-droid>" nix-on-droid)/bin/nix-on-droid switch
|
|
|
|
echo
|
|
echo "Congratulations! Now you have Nix installed with some default packages like bashInteractive, \
|
|
coreutils, cacert and, most importantly, nix-on-droid itself to manage local configuration, see"
|
|
echo " nix-on-droid help"
|
|
echo "or in the config file"
|
|
echo " ~/.config/nixpkgs/nix-on-droid.nix"
|
|
echo
|
|
echo "You can go for the bare nix-on-droid setup or you can configure your phone via home-manager. See \
|
|
config file for further information."
|
|
echo
|
|
fi
|
|
''}
|
|
|
|
set +u
|
|
. "${config.user.home}/.nix-profile/etc/profile.d/nix-on-droid-session-init.sh"
|
|
set -u
|
|
|
|
${lib.optionalString config.build.initialBuild ''
|
|
exec /usr/bin/env bash # otherwise it'll be a limited bash that came with Nix
|
|
''}
|
|
|
|
usershell="${config.user.shell}"
|
|
if [ "$#" -gt 0 ]; then # if script is not called from within nix-on-droid app
|
|
exec /usr/bin/env "$@"
|
|
elif [ -x "$usershell" ]; then
|
|
exec -a "-''${usershell##*/}" "$usershell"
|
|
else
|
|
echo "Cannot execute shell '${config.user.shell}', falling back to bash"
|
|
exec -l bash
|
|
fi
|
|
''
|