изменено: configuration.nix
This commit is contained in:
parent
d6538f1508
commit
c4a72e8944
1 changed files with 167 additions and 219 deletions
|
|
@ -11,17 +11,15 @@
|
||||||
let
|
let
|
||||||
serverIP = "10.0.174.12";
|
serverIP = "10.0.174.12";
|
||||||
hasBootPartition = config.fileSystems ? "/boot";
|
hasBootPartition = config.fileSystems ? "/boot";
|
||||||
|
isNvidia = (builtins.readFile (pkgs.runCommandLocal "isNvidia" {} ''
|
||||||
|
${pkgs.pciutils}/bin/lspci | ${pkgs.busybox}/bin/grep NVIDIA | ${pkgs.busybox}/bin/grep VGA > $out
|
||||||
|
'')) != "";
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
users.users.student = {
|
users.users.student = {
|
||||||
isNormalUser = true;
|
isNormalUser = true;
|
||||||
initialPassword = "student"; # вход беспарольный, но пароль student
|
initialPassword = "student"; # вход беспарольный, но пароль student
|
||||||
extraGroups = [
|
extraGroups = [ "video" "sound" "input" "storage" ];
|
||||||
"video"
|
|
||||||
"sound"
|
|
||||||
"input"
|
|
||||||
"storage"
|
|
||||||
];
|
|
||||||
packages =
|
packages =
|
||||||
let
|
let
|
||||||
# определение как скачивать плагины jetbrains (скачивать с нашего сервера копию)
|
# определение как скачивать плагины jetbrains (скачивать с нашего сервера копию)
|
||||||
|
|
@ -66,7 +64,8 @@ in
|
||||||
#idea-community."2024.1"."R4Intellij"
|
#idea-community."2024.1"."R4Intellij"
|
||||||
idea-community."2024.1"."com.redhat.devtools.lsp4ij"
|
idea-community."2024.1"."com.redhat.devtools.lsp4ij"
|
||||||
])
|
])
|
||||||
++ [
|
++
|
||||||
|
[
|
||||||
# поддежка языка C/C++ на уровне подсветки синтаксиса и автодополнения
|
# поддежка языка C/C++ на уровне подсветки синтаксиса и автодополнения
|
||||||
(customJBPlugin "clsp" "1.0.1" "sha256-AU/Q61YYsGn2BAYykCGm4XGNyeSwd5K/txGNzP2dJg0=")
|
(customJBPlugin "clsp" "1.0.1" "sha256-AU/Q61YYsGn2BAYykCGm4XGNyeSwd5K/txGNzP2dJg0=")
|
||||||
|
|
||||||
|
|
@ -82,14 +81,9 @@ in
|
||||||
sakura # терминал
|
sakura # терминал
|
||||||
unzipNLS # поддержка zip
|
unzipNLS # поддержка zip
|
||||||
unrar # поддержка rar
|
unrar # поддержка rar
|
||||||
gtk3
|
gtk3 whitesur-icon-theme # необходимо для иконок
|
||||||
whitesur-icon-theme # необходимо для иконок
|
(pkgs.writeShellScriptBin "powermenu" (builtins.readFile inputs.mireadesktop.packages.x86_64-linux.powermenu))
|
||||||
(pkgs.writeShellScriptBin "powermenu" (
|
(pkgs.writeShellScriptBin "resethome" (builtins.readFile inputs.mireadesktop.packages.x86_64-linux.resethome))
|
||||||
builtins.readFile inputs.mireadesktop.packages.x86_64-linux.powermenu
|
|
||||||
))
|
|
||||||
(pkgs.writeShellScriptBin "resethome" (
|
|
||||||
builtins.readFile inputs.mireadesktop.packages.x86_64-linux.resethome
|
|
||||||
))
|
|
||||||
|
|
||||||
pandoc
|
pandoc
|
||||||
#onlyoffice-desktopeditors # к сожалению, пока у OnlyOffice баг со шрифтами. Ждём фикс
|
#onlyoffice-desktopeditors # к сожалению, пока у OnlyOffice баг со шрифтами. Ждём фикс
|
||||||
|
|
@ -127,8 +121,7 @@ in
|
||||||
# Другие возможные языки и инструменты, например:
|
# Другие возможные языки и инструменты, например:
|
||||||
# rustc # - Rust
|
# rustc # - Rust
|
||||||
# go gopls delve golint go-tools # - Go
|
# go gopls delve golint go-tools # - Go
|
||||||
jdk
|
jdk kotlin # - Java, Kotlin (идут вместе с IJ IDEA)
|
||||||
kotlin # - Java, Kotlin (идут вместе с IJ IDEA)
|
|
||||||
# ghc haskell-language-server # - Haskell
|
# ghc haskell-language-server # - Haskell
|
||||||
# nodePackages.intelephense # - PHP
|
# nodePackages.intelephense # - PHP
|
||||||
# dotnet-sdk # - C#
|
# dotnet-sdk # - C#
|
||||||
|
|
@ -142,36 +135,9 @@ in
|
||||||
# аналог Bizagi Modeler, расширенный вариант bpmn.io
|
# аналог Bizagi Modeler, расширенный вариант bpmn.io
|
||||||
camunda-modeler
|
camunda-modeler
|
||||||
|
|
||||||
# StarUML
|
|
||||||
# staruml
|
|
||||||
# записано через mkDerivation, чтобы был вечный evalution mode
|
|
||||||
# графическое моделирование UML-диаграмм
|
# графическое моделирование UML-диаграмм
|
||||||
# также доступно моделирование BPMN и ER
|
# также доступно моделирование BPMN и ER
|
||||||
(pkgs.stdenv.mkDerivation rec {
|
staruml
|
||||||
pname = "staruml";
|
|
||||||
version = "6.2.2";
|
|
||||||
src = ./.;
|
|
||||||
nativeBuildInputs = [ pkgs.staruml ];
|
|
||||||
dontBuild = true;
|
|
||||||
installPhase = ''
|
|
||||||
mkdir -p $out/bin
|
|
||||||
cat <<EOF > $out/bin/staruml
|
|
||||||
rm -rf /home/student/.config/StarUML;
|
|
||||||
${pkgs.staruml}/bin/StarUML
|
|
||||||
EOF
|
|
||||||
chmod +x $out/bin/staruml
|
|
||||||
'';
|
|
||||||
desktopItem = pkgs.makeDesktopItem {
|
|
||||||
name = "staruml";
|
|
||||||
exec = "staruml";
|
|
||||||
desktopName = "StarUML";
|
|
||||||
categories = [ "Database" ];
|
|
||||||
icon = "staruml";
|
|
||||||
terminal = false;
|
|
||||||
startupNotify = false;
|
|
||||||
mimeTypes = [ "x-scheme-handler/mdj" ];
|
|
||||||
};
|
|
||||||
})
|
|
||||||
|
|
||||||
# Язык текстового описания UML-диаграмм
|
# Язык текстового описания UML-диаграмм
|
||||||
# актуально для разработчиков ПО (встраивание диаграмм в код)
|
# актуально для разработчиков ПО (встраивание диаграмм в код)
|
||||||
|
|
@ -180,6 +146,7 @@ chmod +x $out/bin/staruml
|
||||||
|
|
||||||
archi # поддержка archimate
|
archi # поддержка archimate
|
||||||
|
|
||||||
|
|
||||||
##### Утилиты и программы для STM32 #####
|
##### Утилиты и программы для STM32 #####
|
||||||
# 1) STM32CubeIDE упаковать не удалось
|
# 1) STM32CubeIDE упаковать не удалось
|
||||||
# 2) есть основания полагать, что её функциональность лучше встроить
|
# 2) есть основания полагать, что её функциональность лучше встроить
|
||||||
|
|
@ -193,10 +160,8 @@ chmod +x $out/bin/staruml
|
||||||
##### СЕТЕВЫЕ УТИЛИТЫ ######
|
##### СЕТЕВЫЕ УТИЛИТЫ ######
|
||||||
# установлен Cisco Packet Tracer, обернут в firejail чтобы не стучался на Netacad.com
|
# установлен Cisco Packet Tracer, обернут в firejail чтобы не стучался на Netacad.com
|
||||||
nodePackages.node-red # - лоукод-платформа программирования устройств, в частности интернета вещей
|
nodePackages.node-red # - лоукод-платформа программирования устройств, в частности интернета вещей
|
||||||
httpie
|
httpie httpie-desktop # - передовой клиент HTTP-запросов
|
||||||
httpie-desktop # - передовой клиент HTTP-запросов
|
netcat socat # - низкоуровневые простейшие утилиты установления TCP или UDP между компьютерами или с ПЛК
|
||||||
netcat
|
|
||||||
socat # - низкоуровневые простейшие утилиты установления TCP или UDP между компьютерами или с ПЛК
|
|
||||||
opcua-client-gui # - простой графический клиент OPC UA
|
opcua-client-gui # - простой графический клиент OPC UA
|
||||||
|
|
||||||
###### Другой софт #######
|
###### Другой софт #######
|
||||||
|
|
@ -223,8 +188,7 @@ chmod +x $out/bin/staruml
|
||||||
|
|
||||||
fhsEnv = pkgs.buildFHSEnv {
|
fhsEnv = pkgs.buildFHSEnv {
|
||||||
name = "${pname}-fhs";
|
name = "${pname}-fhs";
|
||||||
targetPkgs =
|
targetPkgs = p: with p; [
|
||||||
p: with p; [
|
|
||||||
eudev.out
|
eudev.out
|
||||||
libGL.out
|
libGL.out
|
||||||
openal.out
|
openal.out
|
||||||
|
|
@ -259,6 +223,7 @@ chmod +x $out/bin/staruml
|
||||||
'';
|
'';
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
# поставка SimInTech. Кодогенерация библиотек для ПК работает,
|
# поставка SimInTech. Кодогенерация библиотек для ПК работает,
|
||||||
# но несовместима с .dll из windows!
|
# но несовместима с .dll из windows!
|
||||||
#simintech.packages.x86_64-linux.simintech
|
#simintech.packages.x86_64-linux.simintech
|
||||||
|
|
@ -273,8 +238,7 @@ chmod +x $out/bin/staruml
|
||||||
|
|
||||||
fhsEnv = pkgs.buildFHSEnv {
|
fhsEnv = pkgs.buildFHSEnv {
|
||||||
name = "${pname}-fhs-env";
|
name = "${pname}-fhs-env";
|
||||||
targetPkgs =
|
targetPkgs = p: with p; [
|
||||||
p: with p; [
|
|
||||||
at-spi2-atk.out
|
at-spi2-atk.out
|
||||||
gdk-pixbuf.out
|
gdk-pixbuf.out
|
||||||
glamoroustoolkit.out
|
glamoroustoolkit.out
|
||||||
|
|
@ -377,9 +341,7 @@ chmod +x $out/bin/staruml
|
||||||
# если машина установлена на диск с Windows,
|
# если машина установлена на диск с Windows,
|
||||||
# то она позволяет "увидеть" и выбрать Windows в течение 30 с
|
# то она позволяет "увидеть" и выбрать Windows в течение 30 с
|
||||||
# иначе - 5 c таймаута (для виртуалок)
|
# иначе - 5 c таймаута (для виртуалок)
|
||||||
boot.loader =
|
boot.loader = if hasBootPartition then {
|
||||||
if hasBootPartition then
|
|
||||||
{
|
|
||||||
efi.canTouchEfiVariables = true;
|
efi.canTouchEfiVariables = true;
|
||||||
timeout = 30;
|
timeout = 30;
|
||||||
grub = {
|
grub = {
|
||||||
|
|
@ -387,22 +349,14 @@ chmod +x $out/bin/staruml
|
||||||
efiSupport = true;
|
efiSupport = true;
|
||||||
device = "nodev";
|
device = "nodev";
|
||||||
useOSProber = true;
|
useOSProber = true;
|
||||||
theme = "${pkgs.sleek-grub-theme.override {
|
theme = "${pkgs.sleek-grub-theme.override{ withStyle = "orange"; withBanner = "Выберите ОС"; }}";
|
||||||
withStyle = "orange";
|
|
||||||
withBanner = "Выберите ОС";
|
|
||||||
}}";
|
|
||||||
};
|
};
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
timeout = 5;
|
timeout = 5;
|
||||||
grub = {
|
grub = {
|
||||||
enable = true;
|
enable = true;
|
||||||
device = "/dev/sda";
|
device = "/dev/sda";
|
||||||
theme = "${pkgs.sleek-grub-theme.override {
|
theme = "${pkgs.sleek-grub-theme.override{ withStyle = "orange"; withBanner = "Загрузчик Linux"; }}";
|
||||||
withStyle = "orange";
|
|
||||||
withBanner = "Загрузчик Linux";
|
|
||||||
}}";
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
time.hardwareClockInLocalTime = hasBootPartition;
|
time.hardwareClockInLocalTime = hasBootPartition;
|
||||||
|
|
@ -426,35 +380,37 @@ chmod +x $out/bin/staruml
|
||||||
##### НАСТРОЙКИ ГРАФИКИ И РАБОЧЕГО СТОЛА ######
|
##### НАСТРОЙКИ ГРАФИКИ И РАБОЧЕГО СТОЛА ######
|
||||||
hardware.graphics = {
|
hardware.graphics = {
|
||||||
enable = true;
|
enable = true;
|
||||||
enable32Bit = true;
|
#enable32Bit = true;
|
||||||
extraPackages = with pkgs; [ nvidia-vaapi-driver ];
|
extraPackages = if isNvidia then with pkgs; [ nvidia-vaapi-driver vaapiVdpau libvdpau-va-gl] else [];
|
||||||
};
|
};
|
||||||
services.xserver = {
|
services.xserver = {
|
||||||
enable = true;
|
enable = true;
|
||||||
videoDrivers = [
|
videoDrivers = if isNvidia then [ "nvidia" ] else [ "modesetting" "fbdev" ];
|
||||||
"nvidia"
|
|
||||||
"modesetting"
|
|
||||||
"fbdev"
|
|
||||||
];
|
|
||||||
xkb.layout = "us,ru";
|
xkb.layout = "us,ru";
|
||||||
xkb.options = "grp:alt_shift_toggle";
|
xkb.options = "grp:alt_shift_toggle";
|
||||||
};
|
};
|
||||||
hardware.enableAllFirmware = true;
|
hardware.enableAllFirmware = true;
|
||||||
|
#hardware.nvidia = {
|
||||||
|
# package = config.boot.kernelPackages.nvidiaPackages.legacy_470;
|
||||||
|
# modesetting.enable = true;
|
||||||
|
# powerManagement.enable = true;
|
||||||
|
# open = false;
|
||||||
|
# nvidiaSettings = false;
|
||||||
|
#};
|
||||||
hardware.nvidia = {
|
hardware.nvidia = {
|
||||||
package = config.boot.kernelPackages.nvidiaPackages.legacy_470;
|
package = config.boot.kernelPackages.nvidiaPackages.stable;
|
||||||
modesetting.enable = true;
|
modesetting.enable = true;
|
||||||
powerManagement.enable = true;
|
powerManagement.enable = true;
|
||||||
open = false;
|
open = false;
|
||||||
nvidiaSettings = false;
|
nvidiaSettings = false;
|
||||||
};
|
};
|
||||||
boot.blacklistedKernelModules = [ "nouveau" ];
|
boot.kernelParams = if isNvidia then ["nvidia-drm.modeset=1" ] else [];
|
||||||
boot.extraModprobeConfig =
|
boot.blacklistedKernelModules = if isNvidia then [ "nouveau" ] else [];
|
||||||
"options nvidia "
|
boot.extraModprobeConfig = if isNvidia then "options nvidia " + lib.concatStringsSep " " [
|
||||||
+ lib.concatStringsSep " " [
|
|
||||||
"NVreg_UsePageAttributeTable=1"
|
"NVreg_UsePageAttributeTable=1"
|
||||||
"NVreg_EnablePCIeGen3=1"
|
"NVreg_EnablePCIeGen3=1"
|
||||||
"NVreg_RegistryDwords=RMUseSwI2c=0x01;RMI2cSpeed=100"
|
"NVreg_RegistryDwords=RMUseSwI2c=0x01;RMI2cSpeed=100"
|
||||||
];
|
] else "";
|
||||||
|
|
||||||
services.displayManager.autoLogin.user = "student";
|
services.displayManager.autoLogin.user = "student";
|
||||||
services.getty.autologinUser = "student";
|
services.getty.autologinUser = "student";
|
||||||
|
|
@ -485,15 +441,11 @@ chmod +x $out/bin/staruml
|
||||||
##### СЕТЕВЫЕ НАСТРОЙКИ #######
|
##### СЕТЕВЫЕ НАСТРОЙКИ #######
|
||||||
# каждый компьютер виден под уникальным именем через Avahi
|
# каждый компьютер виден под уникальным именем через Avahi
|
||||||
services.avahi = {
|
services.avahi = {
|
||||||
hostName =
|
hostName = "nixos"
|
||||||
"nixos"
|
+ builtins.readFile ((pkgs.runCommandLocal "uuid" {} ''
|
||||||
+ builtins.readFile (
|
|
||||||
(pkgs.runCommandLocal "uuid" { } ''
|
|
||||||
mkdir $out
|
mkdir $out
|
||||||
cat /proc/sys/kernel/random/uuid > $out/uuid
|
cat /proc/sys/kernel/random/uuid > $out/uuid
|
||||||
'')
|
'')+"/uuid");
|
||||||
+ "/uuid"
|
|
||||||
);
|
|
||||||
enable = true;
|
enable = true;
|
||||||
nssmdns4 = true;
|
nssmdns4 = true;
|
||||||
openFirewall = true;
|
openFirewall = true;
|
||||||
|
|
@ -515,10 +467,7 @@ chmod +x $out/bin/staruml
|
||||||
networking.nameservers = [ serverIP ];
|
networking.nameservers = [ serverIP ];
|
||||||
|
|
||||||
# каждый компьютер знает, что kafpi.local - это адрес нашего сервера
|
# каждый компьютер знает, что kafpi.local - это адрес нашего сервера
|
||||||
networking.hosts."${serverIP}" = [
|
networking.hosts."${serverIP}" = [ "kafpi.local" "hydra.kafpi.local" ];
|
||||||
"kafpi.local"
|
|
||||||
"hydra.kafpi.local"
|
|
||||||
];
|
|
||||||
#security.pki.certificateFiles = [
|
#security.pki.certificateFiles = [
|
||||||
# (builtins.fetchurl {
|
# (builtins.fetchurl {
|
||||||
# url = "http://${serverIP}/server.crt";
|
# url = "http://${serverIP}/server.crt";
|
||||||
|
|
@ -550,6 +499,7 @@ chmod +x $out/bin/staruml
|
||||||
liberation_ttf
|
liberation_ttf
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
||||||
####### ПРОЧИЕ НАСТРОЙКИ #######
|
####### ПРОЧИЕ НАСТРОЙКИ #######
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
vim
|
vim
|
||||||
|
|
@ -571,10 +521,7 @@ chmod +x $out/bin/staruml
|
||||||
wrappedBinaries = {
|
wrappedBinaries = {
|
||||||
packettracer7 = {
|
packettracer7 = {
|
||||||
executable = "${packettracer7.packages.x86_64-linux.default}/bin/packettracer7";
|
executable = "${packettracer7.packages.x86_64-linux.default}/bin/packettracer7";
|
||||||
extraArgs = [
|
extraArgs = [ "--net=none" "--noprofile" ];
|
||||||
"--net=none"
|
|
||||||
"--noprofile"
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
@ -598,3 +545,4 @@ chmod +x $out/bin/staruml
|
||||||
# НЕ МЕНЯТЬ, иначе придётся все компы переустанавливать, а не обновлять
|
# НЕ МЕНЯТЬ, иначе придётся все компы переустанавливать, а не обновлять
|
||||||
system.stateVersion = "24.05";
|
system.stateVersion = "24.05";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue