2015-10-30 16:05:51 +01:00
{ config , lib , pkgs , . . . }:
2016-10-20 20:54:38 +02:00
with import <stockholm/lib> ;
2016-07-07 23:07:22 +02:00
2015-10-30 16:05:51 +01:00
let
2016-04-08 03:53:34 +02:00
ip = config . krebs . build . host . nets . internet . ip4 . addr ;
2016-05-20 00:02:29 +02:00
2016-05-31 23:26:35 +02:00
inherit ( import <stockholm/lass/2configs/websites/util.nix> { inherit lib pkgs ; } )
manageCerts
;
2016-05-20 00:02:29 +02:00
2015-10-30 16:05:51 +01:00
in {
imports = [
2016-02-15 16:27:11 +01:00
../.
2017-01-10 19:40:32 +01:00
{
networking . interfaces . et0 . ip4 = [
{
address = ip ;
prefixLength = 24 ;
}
] ;
networking . defaultGateway = " 2 1 3 . 2 3 9 . 2 0 5 . 2 2 5 " ;
networking . nameservers = [
" 8 . 8 . 8 . 8 "
] ;
services . udev . extraRules = ''
SUBSYSTEM == " n e t " , ATTR { address } == " 5 4 : 0 4 : a 6 : 7 e : f 4 : 0 6 " , NAME = " e t 0 "
'' ;
}
2016-08-24 00:03:38 +02:00
../2configs/retiolum.nix
2016-04-12 15:17:42 +02:00
../2configs/exim-smarthost.nix
2015-10-30 16:05:51 +01:00
../2configs/downloading.nix
2015-11-01 19:58:59 +01:00
../2configs/ts3.nix
2015-11-09 02:27:22 +01:00
../2configs/bitlbee.nix
2015-11-13 14:57:51 +01:00
../2configs/weechat.nix
2016-04-15 16:15:22 +02:00
../2configs/privoxy-retiolum.nix
2016-05-21 13:49:31 +02:00
../2configs/radio.nix
2016-05-31 23:34:06 +02:00
../2configs/buildbot-standalone.nix
2016-06-24 15:35:47 +02:00
../2configs/repo-sync.nix
2016-06-25 18:56:39 +02:00
../2configs/binary-cache/server.nix
2016-09-13 00:04:48 +02:00
../2configs/iodined.nix
2016-12-26 13:50:42 +01:00
../2configs/libvirt.nix
2016-12-26 14:23:52 +01:00
../2configs/hfos.nix
2016-12-29 18:15:41 +01:00
../2configs/makefu-sip.nix
2017-01-30 22:58:39 +01:00
../2configs/monitoring/server.nix
2017-02-13 17:17:55 +01:00
../2configs/monitoring/monit-alarms.nix
2017-04-11 21:40:42 +02:00
../2configs/paste.nix
2017-01-31 17:14:30 +01:00
{
imports = [
../2configs/bepasty.nix
] ;
krebs . bepasty . servers . " p a s t e . r " . nginx . extraConfig = ''
if ( $ server_addr = " ${ config . krebs . build . host . nets . internet . ip4 . addr } " ) {
return 403 ;
}
'' ;
}
2015-10-30 16:05:51 +01:00
{
users . extraGroups = {
# ● systemd-tmpfiles-setup.service - Create Volatile Files and Directories
# Loaded: loaded (/nix/store/2l33gg7nmncqkpysq9f5fxyhlw6ncm2j-systemd-217/example/systemd/system/systemd-tmpfiles-setup.service)
# Active: failed (Result: exit-code) since Mon 2015-03-16 10:29:18 UTC; 4s ago
# Docs: man:tmpfiles.d(5)
# man:systemd-tmpfiles(8)
# Process: 19272 ExecStart=/nix/store/2l33gg7nmncqkpysq9f5fxyhlw6ncm2j-systemd-217/bin/systemd-tmpfiles --create --remove --boot --exclude-prefix=/dev (code=exited, status=1/FAILURE)
# Main PID: 19272 (code=exited, status=1/FAILURE)
#
# Mar 16 10:29:17 cd systemd-tmpfiles[19272]: [/usr/lib/tmpfiles.d/legacy.conf:26] Unknown group 'lock'.
# Mar 16 10:29:18 cd systemd-tmpfiles[19272]: Two or more conflicting lines for /var/log/journal configured, ignoring.
# Mar 16 10:29:18 cd systemd-tmpfiles[19272]: Two or more conflicting lines for /var/log/journal/7b35116927d74ea58785e00b47ac0f0d configured, ignoring.
# Mar 16 10:29:18 cd systemd[1]: systemd-tmpfiles-setup.service: main process exited, code=exited, status=1/FAILURE
# Mar 16 10:29:18 cd systemd[1]: Failed to start Create Volatile Files and Directories.
# Mar 16 10:29:18 cd systemd[1]: Unit systemd-tmpfiles-setup.service entered failed state.
# Mar 16 10:29:18 cd systemd[1]: systemd-tmpfiles-setup.service failed.
# warning: error(s) occured while switching to the new configuration
lock . gid = 10001 ;
} ;
}
{
boot . loader . grub = {
devices = [
" / d e v / s d a "
" / d e v / s d b "
] ;
splashImage = null ;
} ;
boot . initrd . availableKernelModules = [
" a t a _ p i i x "
" v m w _ p v s c s i "
] ;
fileSystems . " / " = {
device = " / d e v / p o o l / n i x " ;
fsType = " e x t 4 " ;
} ;
fileSystems . " / b o o t " = {
device = " / d e v / d i s k / b y - u u i d / 7 c a 1 2 d 8 c - 6 0 6 d - 4 1 c e - b 1 0 d - 6 2 b 6 5 4 e 5 0 e 3 6 " ;
} ;
fileSystems . " / v a r / d o w n l o a d " = {
device = " / d e v / p o o l / d o w n l o a d " ;
} ;
2016-04-11 16:43:52 +02:00
fileSystems . " / s r v / h t t p " = {
device = " / d e v / p o o l / h t t p " ;
} ;
fileSystems . " / s r v / o . u b i k m e d i a . d e - d a t a " = {
device = " / d e v / p o o l / o w n c l o u d - u b i k - d a t a " ;
} ;
fileSystems . " / b k u " = {
device = " / d e v / p o o l / b k u " ;
2016-04-09 00:18:51 +02:00
} ;
2016-10-11 17:35:53 +02:00
fileSystems . " / t m p " = {
device = " t m p f s " ;
fsType = " t m p f s " ;
options = [ " n o s u i d " " n o d e v " " n o a t i m e " ] ;
} ;
2015-10-30 16:05:51 +01:00
}
{
sound . enable = false ;
}
2015-11-01 20:00:43 +01:00
{
nixpkgs . config . allowUnfree = true ;
}
2015-11-09 02:33:30 +01:00
{
#stuff for juhulian
users . extraUsers . juhulian = {
name = " j u h u l i a n " ;
uid = 1339 ;
home = " / h o m e / j u h u l i a n " ;
group = " u s e r s " ;
createHome = true ;
useDefaultShell = true ;
extraGroups = [
] ;
openssh . authorizedKeys . keys = [
" s s h - r s a A A A A B 3 N z a C 1 y c 2 E A A A A D A Q A B A A A B A Q D B Q h L G v f v 4 h y Q / n q J G y 1 Y g H X P S V l 6 i g e W T r o J S v A h U F g o h + r G + z v q Y 0 E a h K X N b 3 s q 0 / O Y D C T J V u u c c 0 h g C g 7 T 2 K q T q M t T b 9 E E k R m C F b D 7 F 7 D W Z o j C r h / a n 6 s H n e q T 5 e F v z A P Z 8 E 5 h u p 7 o V Q n j 5 P 5 M 3 I 9 k e R H B W t 1 r q 6 q 0 I c O E h s F v n e 4 q J c 7 3 a L A S T J k x z l o 5 U 8 j u 3 J Q O l 6 4 7 4 E C u S n 0 l b 1 f T r Q / S R 1 N g F 7 j V 1 1 e B l d k S 8 S H E B + 2 G X j n 4 Y r n + Q U K O n D p + B 8 5 v Z m V l J S I + 7 X R 1 / U / x I b t A j G T E m N w B 6 c T b B v 9 N C G 9 j l o D D O Z G 4 Z v z z H Y r l B X j a i g t Q h 2 / 4 m r H o K a 5 e V j u h u l i a n @ j u h u l i a n "
] ;
} ;
krebs . iptables . tables . filter . INPUT . rules = [
{ predicate = " - p u d p - - d p o r t 6 0 0 0 0 : 6 1 0 0 0 " ; target = " A C C E P T " ; }
] ;
}
2015-11-13 01:06:16 +01:00
{
environment . systemPackages = [
pkgs . perlPackages . Plack
] ;
krebs . iptables . tables . filter . INPUT . rules = [
{ predicate = " - p t c p - - d p o r t 8 0 8 0 " ; target = " A C C E P T " ; }
] ;
}
2015-12-12 17:58:21 +01:00
{
users . users . chat . openssh . authorizedKeys . keys = [
2017-04-13 15:25:37 +02:00
" s s h - r s a A A A A B 3 N z a C 1 y c 2 E A A A A D A Q A B A A A C A Q D j e s i O n h p T 9 X g W Z q w / 6 4 M 5 l V Q g 3 q 0 k 2 2 B t M y C v + 3 3 s G X 8 V m f T y D 1 1 G u w S j N G f 5 W i s w K L q F v Y B Q s H f D D t S 3 k 0 Z N T D n c G w 3 P b i l m 6 Q o C u H E y D P a Q Y i n 0 P + J m k o c r L / 6 Q F 5 u h Z V F n s X C H 5 w n t w O a 0 0 V F G w p M g Q Y S f R l R e R x 4 2 P u 9 J k + i J d u Z M R B b O M v J I 6 8 Z 7 i J 4 D g W / 1 U 9 J 4 M Q d C s k 7 Q l F g U s t Q Q f V 1 z k 4 V f V f X u x D P 3 h j x 6 Q 0 5 n D C h j p m z J b F u n z b 7 a i y / 1 / S l 0 Q h R O T p v x r Q L k s g 7 y Y L w 4 B R s 9 p t j e h X 4 5 A 2 S x i 8 W K O b / g 5 u 3 x J N y 0 X 0 7 r E + N + o 5 v 2 h S 7 w F 0 D L Q d K 5 + 4 T G t O + Y + A B U C q q A + T 1 y n A j N B W v s g Y 5 u D 4 P Z j u P g C M S w 0 J B m I y / P 0 T H i 3 v 5 / 8 C o h v f n s p l 7 J p f 8 0 q E N M u 3 u n v v E 9 E e P z g S R Z Y 1 P v D j P Q f k W y 0 y B X 1 y Q M h H u V G k e 9 Q g a l e t i t w u a h R u j m l 3 7 w a e U u O l 8 R p z + 2 i V + 6 O I S 4 t f O 3 6 8 u L F H K W b o b X T b T D X O D B g x Z / I y v O 7 v x M 2 u D X / k I W a e Y K r i p 3 n S y W B Y n i x w r c S 4 v m 6 Z Q c o e j w p 2 K C f G Q w I E 4 M n G Y R l w c O E Y j v y j L k Z H D i Z E i v U Q 0 r T h M Y B z e c 8 b Q 0 8 Q W 8 o x F + N X k F K G 3 a w t 3 f 7 T K T R k Y q Q c O M p F K m V 2 4 K D i w g w m 0 m i Q = = J u i c e S S H "
2015-12-12 17:58:21 +01:00
] ;
}
2015-12-12 17:58:58 +01:00
{
time . timeZone = " E u r o p e / B e r l i n " ;
}
2015-12-12 18:22:47 +01:00
{
imports = [
../2configs/websites/domsen.nix
2016-10-19 14:58:46 +02:00
../2configs/websites/lassulus.nix
2015-12-12 18:22:47 +01:00
] ;
krebs . iptables . tables . filter . INPUT . rules = [
2016-04-09 00:36:38 +02:00
{ predicate = " - p t c p - - d p o r t h t t p " ; target = " A C C E P T " ; }
{ predicate = " - p t c p - - d p o r t h t t p s " ; target = " A C C E P T " ; }
2015-12-12 18:22:47 +01:00
] ;
}
2016-03-06 01:45:57 +01:00
{
services . tor = {
enable = true ;
} ;
}
2016-05-20 00:02:29 +02:00
{
lass . ejabberd = {
enable = true ;
hosts = [ " l a s s u l . u s " ] ;
} ;
krebs . iptables . tables . filter . INPUT . rules = [
{ predicate = " - p t c p - - d p o r t x m p p - c l i e n t " ; target = " A C C E P T " ; }
{ predicate = " - p t c p - - d p o r t x m p p - s e r v e r " ; target = " A C C E P T " ; }
] ;
}
2016-05-24 23:55:11 +02:00
{
imports = [
2016-06-25 18:38:30 +02:00
../2configs/realwallpaper.nix
2016-05-24 23:55:11 +02:00
] ;
2016-12-26 14:18:08 +01:00
services . nginx . virtualHosts . " l a s s u l . u s " . locations . " / w a l l p a p e r . p n g " . extraConfig = ''
alias /tmp/wallpaper.png ;
'' ;
2016-05-24 23:55:11 +02:00
}
2016-07-08 13:42:12 +02:00
{
environment . systemPackages = with pkgs ; [
mk_sql_pair
] ;
}
2016-07-10 18:06:50 +02:00
{
users . users . tv = {
uid = genid " t v " ;
2016-07-19 00:01:17 +02:00
inherit ( config . krebs . users . tv ) home ;
2016-07-10 18:06:50 +02:00
group = " u s e r s " ;
createHome = true ;
useDefaultShell = true ;
openssh . authorizedKeys . keys = [
config . krebs . users . tv . pubkey
] ;
} ;
}
2016-09-08 21:01:55 +02:00
{
krebs . repo-sync . timerConfig = {
2017-03-08 01:06:04 +01:00
OnBootSec = " 1 5 m i n " ;
OnUnitInactiveSec = " 9 0 m i n " ;
RandomizedDelaySec = " 3 0 m i n " ;
} ;
krebs . repo-sync . repos . stockholm . timerConfig = {
2017-03-05 00:21:53 +01:00
OnBootSec = " 5 m i n " ;
2017-03-08 01:06:04 +01:00
OnUnitInactiveSec = " 2 m i n " ;
2017-02-07 17:13:07 +01:00
RandomizedDelaySec = " 2 m i n " ;
2016-09-08 21:01:55 +02:00
} ;
}
2016-10-27 12:49:48 +02:00
{
lass . usershadow = {
enable = true ;
} ;
}
2017-01-16 17:25:21 +01:00
{
2017-01-26 23:44:31 +01:00
# Nin stuff
2017-01-16 17:25:21 +01:00
users . users . nin = {
uid = genid " n i n " ;
inherit ( config . krebs . users . nin ) home ;
group = " u s e r s " ;
createHome = true ;
useDefaultShell = true ;
openssh . authorizedKeys . keys = [
config . krebs . users . nin . pubkey
] ;
extraGroups = [
" l i b v i r t d "
] ;
} ;
2017-01-21 18:37:48 +01:00
krebs . iptables . tables . nat . PREROUTING . rules = [
{ v6 = false ; precedence = 1000 ; predicate = " - d 2 1 3 . 2 3 9 . 2 0 5 . 2 4 0 - p t c p - - d p o r t 1 3 3 7 " ; target = " D N A T - - t o - d e s t i n a t i o n 1 9 2 . 1 6 8 . 1 2 2 . 2 4 : 2 2 " ; }
] ;
krebs . iptables . tables . filter . FORWARD . rules = [
{ v6 = false ; precedence = 1000 ; predicate = " - d 1 9 2 . 1 6 8 . 1 2 2 . 2 4 - p t c p - - d p o r t 2 2 - m s t a t e - - s t a t e N E W , E S T A B L I S H E D , R E L A T E D " ; target = " A C C E P T " ; }
] ;
2017-01-16 17:25:21 +01:00
}
2017-01-21 22:08:12 +01:00
{
2017-04-13 15:25:04 +02:00
krebs . Reaktor . coders = {
nickname = " R e a k t o r | l a s s " ;
2017-01-21 22:08:12 +01:00
channels = [ " # c o d e r s " ] ;
extraEnviron = {
REAKTOR_HOST = " i r c . h a c k i n t . o r g " ;
} ;
2017-01-21 23:50:48 +01:00
plugins = with pkgs . ReaktorPlugins ; let
2017-04-13 15:25:04 +02:00
lambdabot = ( import ( pkgs . fetchFromGitHub {
owner = " N i x O S " ; repo = " n i x p k g s " ;
rev = " a 4 e c 1 8 4 1 d a 1 4 f c 9 8 c 5 c 3 5 c c 7 2 2 4 2 c 2 3 b b 6 9 8 d 4 a c " ;
sha256 = " 1 4 8 f p w 3 1 s 9 2 2 h x r f 2 8 y h r c i 2 9 6 f 7 c 7 z d 8 1 h f 0 k 6 z s 0 5 r q 0 i 3 s z g y " ;
} ) { } ) . lambdabot ;
2017-01-21 23:50:48 +01:00
lambdabotflags = ''
- XStandaloneDeriving - XGADTs - XFlexibleContexts \
- XFlexibleInstances - XMultiParamTypeClasses \
- XOverloadedStrings - XFunctionalDependencies \ '' ;
in [
2017-01-21 22:08:12 +01:00
url-title
( buildSimpleReaktorPlugin " l a m b d a b o t - p l " {
2017-01-23 13:37:52 +01:00
pattern = " ^ @ p l ( ? P < a r g s > . * ) $ $ " ;
2017-01-21 22:08:12 +01:00
script = pkgs . writeDash " l a m b d a - p l " ''
2017-02-18 20:31:42 +01:00
exec $ { lambdabot } /bin/lambdabot \
2017-01-21 23:50:48 +01:00
$ { indent lambdabotflags }
- e " @ p l $ 1 "
2017-01-21 22:08:12 +01:00
'' ;
} )
( buildSimpleReaktorPlugin " l a m b d a b o t - t y p e " {
2017-01-23 13:37:52 +01:00
pattern = " ^ @ t y p e ( ? P < a r g s > . * ) $ $ " ;
2017-01-21 22:08:12 +01:00
script = pkgs . writeDash " l a m b d a - t y p e " ''
2017-02-18 20:31:42 +01:00
exec $ { lambdabot } /bin/lambdabot \
2017-01-21 23:50:48 +01:00
$ { indent lambdabotflags }
- e " @ t y p e $ 1 "
2017-01-21 22:08:12 +01:00
'' ;
} )
( buildSimpleReaktorPlugin " l a m b d a b o t - l e t " {
2017-01-23 13:37:52 +01:00
pattern = " ^ @ l e t ( ? P < a r g s > . * ) $ $ " ;
2017-01-21 22:08:12 +01:00
script = pkgs . writeDash " l a m b d a - l e t " ''
2017-02-18 20:31:42 +01:00
exec $ { lambdabot } /bin/lambdabot \
2017-01-21 23:50:48 +01:00
$ { indent lambdabotflags }
- e " @ l e t $ 1 "
2017-01-21 22:08:12 +01:00
'' ;
} )
( buildSimpleReaktorPlugin " l a m b d a b o t - r u n " {
2017-01-23 13:37:52 +01:00
pattern = " ^ @ r u n ( ? P < a r g s > . * ) $ $ " ;
2017-01-21 22:08:12 +01:00
script = pkgs . writeDash " l a m b d a - r u n " ''
2017-02-18 20:31:42 +01:00
exec $ { lambdabot } /bin/lambdabot \
2017-01-21 23:50:48 +01:00
$ { indent lambdabotflags }
- e " @ r u n $ 1 "
2017-01-21 22:08:12 +01:00
'' ;
} )
( buildSimpleReaktorPlugin " l a m b d a b o t - k i n d " {
2017-01-23 13:37:52 +01:00
pattern = " ^ @ k i n d ( ? P < a r g s > . * ) $ $ " ;
2017-01-21 22:08:12 +01:00
script = pkgs . writeDash " l a m b d a - k i n d " ''
2017-02-18 20:31:42 +01:00
exec $ { lambdabot } /bin/lambdabot \
2017-01-21 23:50:48 +01:00
$ { indent lambdabotflags }
- e " @ k i n d $ 1 "
2017-01-21 22:08:12 +01:00
'' ;
} )
2017-01-23 13:37:52 +01:00
( buildSimpleReaktorPlugin " l a m b d a b o t - k i n d " {
pattern = " ^ @ k i n d ( ? P < a r g s > . * ) $ $ " ;
script = pkgs . writeDash " l a m b d a - k i n d " ''
2017-02-18 20:31:42 +01:00
exec $ { lambdabot } /bin/lambdabot \
2017-01-23 13:37:52 +01:00
$ { indent lambdabotflags }
- e " @ k i n d $ 1 "
'' ;
} )
( buildSimpleReaktorPlugin " r a n d o m - u n i c o r n - p o r n " {
pattern = " ^ ! r u p $ $ " ;
script = pkgs . writePython2 " r u p " ''
#!${pkgs.python2}/bin/python
t1 = " " "
2017-01-26 23:53:46 +01:00
_ .
; = ' , _ ( )
8 == = D ~ ~ S " . - - ` | |
sS \ __ ||
__ . ' ( \ - -> ||
_ = / _./- \ / ||
8 == = D ~ ~ ( ( \ ( /- ' - ' l ||
) | / \ \ ( _ ) )
\ \ \ \
' ~ ' ~
2017-01-23 13:37:52 +01:00
" " "
print ( t1 )
'' ;
} )
( buildSimpleReaktorPlugin " p i n g " {
pattern = " ^ ! p i n g ( ? P < a r g s > . * ) $ $ " ;
script = pkgs . writeDash " p i n g " ''
exec /var/setuid-wrappers/ping - q - c1 " $ 1 " 2 > & 1 | tail -1
'' ;
} )
2017-01-21 22:08:12 +01:00
] ;
} ;
}
2017-04-13 15:25:28 +02:00
{
krebs . Reaktor . prism = {
nickname = " R e a k t o r | l a s s " ;
channels = [ " # r e t i o l u m " ] ;
extraEnviron = {
REAKTOR_HOST = " n i . r " ;
} ;
plugins = with pkgs . ReaktorPlugins ; [
sed-plugin
] ;
} ;
}
2015-10-30 16:05:51 +01:00
] ;
krebs . build . host = config . krebs . hosts . prism ;
}