Compare commits
7 Commits
2017-06-01
...
2017-06-22
| Author | SHA1 | Date | |
|---|---|---|---|
| ad0799f08d | |||
|
|
4dbcc8ddc0 | ||
|
|
3a5ae68f3a | ||
| 772cab2253 | |||
| 92bf72c7bf | |||
| 60f466a887 | |||
| eca3d77610 |
@@ -14,5 +14,8 @@ mkIf flags.graphical {
|
|||||||
# Gestion de FS
|
# Gestion de FS
|
||||||
gparted # Gestion graphique de partitions
|
gparted # Gestion graphique de partitions
|
||||||
unetbootin # création de clefs USB bootables
|
unetbootin # création de clefs USB bootables
|
||||||
|
|
||||||
|
# visualisation de log
|
||||||
|
#logstalgia
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,12 +24,14 @@ mkIf currentMachine.profiles.isDesktopEnvironment {
|
|||||||
gnome3.adwaita-icon-theme # thème d'icone - semble fonctionner avec spaceFM
|
gnome3.adwaita-icon-theme # thème d'icone - semble fonctionner avec spaceFM
|
||||||
|
|
||||||
## Manipulation de fichier
|
## Manipulation de fichier
|
||||||
pcmanfm # gestionnaire de fichiers graphique
|
#kde5.dolphin # gestionnaire de fichiers graphique
|
||||||
spaceFM # gestionnaire de fichiers graphique
|
#kde5.dolphin-plugins # gestionnaire de fichiers graphique
|
||||||
#vifm # gestionnaire de fichiers basé sur VIM (console)
|
pcmanfm # gestionnaire de fichiers graphique
|
||||||
|
spaceFM # gestionnaire de fichiers graphique
|
||||||
|
#vifm # gestionnaire de fichiers basé sur VIM (console)
|
||||||
|
|
||||||
## Terminal
|
## Terminal
|
||||||
sakura # terminal
|
sakura # terminal
|
||||||
];
|
];
|
||||||
|
|
||||||
# Polices supplémentaires
|
# Polices supplémentaires
|
||||||
|
|||||||
@@ -18,17 +18,17 @@ mkIf flags.developpement-haskell {
|
|||||||
stack # pour les paquets en LTS de stackage
|
stack # pour les paquets en LTS de stackage
|
||||||
] ++ (with pkgs.haskellPackages; [
|
] ++ (with pkgs.haskellPackages; [
|
||||||
# Haskell lib
|
# Haskell lib
|
||||||
autoproc # ? procmail
|
autoproc # ? procmail
|
||||||
darcs # Gestionnaire de version éponyme
|
darcs # gestionnaire de version éponyme
|
||||||
ghc-mod
|
ghc-mod # outil d'analyse de code haskell utilisé par IDE
|
||||||
hindent # indentation code
|
hindent # indentation code
|
||||||
hlint # qualite de code, analyse statique de code + astuces & bonnes pratiques
|
hlint # qualite de code, analyse statique de code + astuces & bonnes pratiques
|
||||||
pandoc-filter-graphviz # filtre pour utiliser graphviz à partir de pandoc
|
postgrest # mapper HTTP <-> PostgreSQL
|
||||||
#postgrest # mapper HTTP <-> PostgreSQL
|
stylish-haskell # qualité de code
|
||||||
stylish-haskell # qualité de code
|
turtle # genre shell-scripting
|
||||||
turtle # genre shell-scripting
|
|
||||||
|
|
||||||
# Application perso
|
# Application perso
|
||||||
hahp
|
hahp
|
||||||
|
pandoc-filter-graphviz # filtre pour utiliser graphviz à partir de pandoc
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,6 +11,10 @@ mkIf flags.developpement {
|
|||||||
|
|
||||||
# Paquets
|
# Paquets
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
|
# Base de données
|
||||||
|
pg_top # monitoring de PostgreSQL
|
||||||
|
sqlite # le moteur de base de données
|
||||||
|
|
||||||
# C / C++
|
# C / C++
|
||||||
gcc # pour les appels depuis les scripts
|
gcc # pour les appels depuis les scripts
|
||||||
|
|
||||||
|
|||||||
@@ -15,18 +15,13 @@ in
|
|||||||
# TODO camel case partout
|
# TODO camel case partout
|
||||||
# TODO everything in english
|
# TODO everything in english
|
||||||
# TODO sortir ce qui est privé
|
# TODO sortir ce qui est privé
|
||||||
# TODO portage du système d'annuaire de machines de capgemini
|
|
||||||
###### interface
|
###### interface
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
#* Utilisé pour avoir des raccourcis de machine
|
#* Utilisé pour avoir des raccourcis de machine
|
||||||
r6d.computers = {
|
r6d.computers = {
|
||||||
isLatitude = mkEnableOption "Identification du nom de machine.";
|
|
||||||
isMonstre = mkEnableOption "Identification du nom de machine.";
|
|
||||||
isNeoNomade = mkEnableOption "Identification du nom de machine.";
|
isNeoNomade = mkEnableOption "Identification du nom de machine.";
|
||||||
isNomade = mkEnableOption "Identification du nom de machine.";
|
isNomade = mkEnableOption "Identification du nom de machine.";
|
||||||
isPedro = mkEnableOption "Identification du nom de machine.";
|
|
||||||
isPhenom = mkEnableOption "Identification du nom de machine.";
|
|
||||||
isRollo = mkEnableOption "Identification du nom de machine.";
|
isRollo = mkEnableOption "Identification du nom de machine.";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@@ -58,28 +53,6 @@ in
|
|||||||
|
|
||||||
## Affectation des profils aux machines
|
## Affectation des profils aux machines
|
||||||
|
|
||||||
(mkIf comp.isLatitude {
|
|
||||||
networking.hostName = "latitude.dubronetwork.fr"; # Define your hostname.
|
|
||||||
r6d.profiles = {
|
|
||||||
isDubronetwork = true;
|
|
||||||
isWorkstation = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
r6d.config-generator = {
|
|
||||||
jetbrains-licensed = true;
|
|
||||||
laptop = true;
|
|
||||||
nix-serve-client = true;
|
|
||||||
nix-serve-server = true;
|
|
||||||
tincAddress = "192.168.12.2/24";
|
|
||||||
tincExtraConfig = ''
|
|
||||||
ConnectTo = monstre_dubronetwork_fr
|
|
||||||
ConnectTo = rollo_dubronetwork_fr
|
|
||||||
ConnectTo = hydra_prunetwork_fr
|
|
||||||
ConnectTo = ocean_prunetwork_fr
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
})
|
|
||||||
|
|
||||||
(mkIf comp.isNeoNomade{
|
(mkIf comp.isNeoNomade{
|
||||||
networking.hostName = "neo-nomade.dubronetwork.fr"; # Define your hostname.
|
networking.hostName = "neo-nomade.dubronetwork.fr"; # Define your hostname.
|
||||||
r6d.profiles = {
|
r6d.profiles = {
|
||||||
@@ -110,38 +83,6 @@ in
|
|||||||
laptop = true;
|
laptop = true;
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
(mkIf comp.isPedro {
|
|
||||||
r6d.profiles = {
|
|
||||||
isDubronetwork = true;
|
|
||||||
isServer = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
r6d.config-generator = {
|
|
||||||
fail2ban = true;
|
|
||||||
};
|
|
||||||
})
|
|
||||||
(mkIf comp.isPhenom {
|
|
||||||
networking.hostName = "phenom.dubronetwork.fr"; # Define your hostname.
|
|
||||||
r6d.profiles = {
|
|
||||||
isDubronetwork = true;
|
|
||||||
isWorkstation = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
r6d.config-generator = {
|
|
||||||
jetbrains-licensed = true;
|
|
||||||
#hydra-core = true;
|
|
||||||
nix-serve-client = true;
|
|
||||||
nix-serve-server = true;
|
|
||||||
edition-photo = true;
|
|
||||||
tincAddress = "192.168.12.1/24";
|
|
||||||
tincExtraConfig = ''
|
|
||||||
ConnectTo = monstre_dubronetwork_fr
|
|
||||||
ConnectTo = rollo_dubronetwork_fr
|
|
||||||
ConnectTo = hydra_prunetwork_fr
|
|
||||||
ConnectTo = ocean_prunetwork_fr
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
})
|
|
||||||
(mkIf comp.isRollo {
|
(mkIf comp.isRollo {
|
||||||
networking.hostName = "rollo.dubronetwork.fr"; # Define your hostname.
|
networking.hostName = "rollo.dubronetwork.fr"; # Define your hostname.
|
||||||
r6d.profiles = {
|
r6d.profiles = {
|
||||||
|
|||||||
@@ -20,6 +20,7 @@
|
|||||||
# Logs
|
# Logs
|
||||||
lol = log --graph --decorate --pretty=oneline --abbrev-commit
|
lol = log --graph --decorate --pretty=oneline --abbrev-commit
|
||||||
lola = log --graph --decorate --pretty=oneline --abbrev-commit --all
|
lola = log --graph --decorate --pretty=oneline --abbrev-commit --all
|
||||||
|
not-pushed = log --branches --not --remotes
|
||||||
[push]
|
[push]
|
||||||
default = simple
|
default = simple
|
||||||
[core]
|
[core]
|
||||||
|
|||||||
@@ -40,6 +40,7 @@ let
|
|||||||
multimediaSuite = mkEnableOption "Profil pour la suite multimédia.";
|
multimediaSuite = mkEnableOption "Profil pour la suite multimédia.";
|
||||||
munin = mkEnableOption "Profil pour activer la supervision par Munin";
|
munin = mkEnableOption "Profil pour activer la supervision par Munin";
|
||||||
murmur = mkEnableOption "Profil pour activer un serveur Mumble (murmur)";
|
murmur = mkEnableOption "Profil pour activer un serveur Mumble (murmur)";
|
||||||
|
nixos-manual = mkEnableOption "Profil pour activer la documentation nixos en local sur un TTY";
|
||||||
nix-serve-server = mkEnableOption "Profil pour que la machine soit un serveur de cache nix.";
|
nix-serve-server = mkEnableOption "Profil pour que la machine soit un serveur de cache nix.";
|
||||||
nixStoreProxyCache = mkEnableOption "Profil pour activer le proxy cahce nginx pour le nix store";
|
nixStoreProxyCache = mkEnableOption "Profil pour activer le proxy cahce nginx pour le nix store";
|
||||||
officeSuite = mkEnableOption "Profil pour la suite bureautique";
|
officeSuite = mkEnableOption "Profil pour la suite bureautique";
|
||||||
|
|||||||
@@ -26,6 +26,7 @@ in
|
|||||||
./kibana.nix # service de visualisation de données stockées dans elasticsearch
|
./kibana.nix # service de visualisation de données stockées dans elasticsearch
|
||||||
# TODO: réactiver locate
|
# TODO: réactiver locate
|
||||||
#./locate.nix # service locate
|
#./locate.nix # service locate
|
||||||
|
./nixos-manual.nix # documentation nixos sur TTY
|
||||||
./virtualbox.nix # activer virtualbox
|
./virtualbox.nix # activer virtualbox
|
||||||
./xmonad/xmonad.nix # pour le gestionaire de fenêtre xmonad
|
./xmonad/xmonad.nix # pour le gestionaire de fenêtre xmonad
|
||||||
|
|
||||||
|
|||||||
33
services/nixos-manual.nix
Normal file
33
services/nixos-manual.nix
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
{ config, lib, pkgs, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
inherit (lib) mkIf mkMerge mkThenElse;
|
||||||
|
annuaire = config.r6d.machines;
|
||||||
|
currentMachine = annuaire."${config.networking.hostName}";
|
||||||
|
flags = currentMachine.configurationFlags;
|
||||||
|
in
|
||||||
|
|
||||||
|
mkIf flags.nixos-manual {
|
||||||
|
|
||||||
|
# Paquets
|
||||||
|
environment.systemPackages = with pkgs; [
|
||||||
|
bc
|
||||||
|
mailutils
|
||||||
|
];
|
||||||
|
|
||||||
|
# Services
|
||||||
|
|
||||||
|
## documentation sur ctrl + alt + F8
|
||||||
|
services.nixosManual = {
|
||||||
|
enable = true;
|
||||||
|
showManual = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
# Réseau
|
||||||
|
networking.firewall = {
|
||||||
|
allowedTCPPorts = [
|
||||||
|
];
|
||||||
|
allowedUDPPorts = [
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user