diff options
author | Emil Renner Berthing <esmil@labitat.dk> | 2018-10-02 22:26:17 +0200 |
---|---|---|
committer | Emil Renner Berthing <esmil@labitat.dk> | 2018-10-03 21:09:55 +0200 |
commit | 7cc8370ab5e3428c24f37b7259331b10038b6acb (patch) | |
tree | 3a54b887aed7b40662b267bba5edcf82fc29464e | |
parent | 4f98942a50341c2827ace103f153374f0b351135 (diff) | |
download | labitat-ansible-7cc8370ab5e3428c24f37b7259331b10038b6acb.tar.gz labitat-ansible-7cc8370ab5e3428c24f37b7259331b10038b6acb.tar.xz labitat-ansible-7cc8370ab5e3428c24f37b7259331b10038b6acb.zip |
jumbotron: add role to set up jumbotron rpi
-rw-r--r-- | inventory | 1 | ||||
-rw-r--r-- | jumbotron.yml | 11 | ||||
-rw-r--r-- | roles/jumbotron/files/autologin | 3 | ||||
-rw-r--r-- | roles/jumbotron/files/bash_profile | 5 | ||||
-rw-r--r-- | roles/jumbotron/files/eth0.network | 6 | ||||
-rw-r--r-- | roles/jumbotron/files/getty@tty1.service.d/autologin.conf | 3 | ||||
-rw-r--r-- | roles/jumbotron/files/getty@tty1.service.d/noclear.conf | 2 | ||||
-rw-r--r-- | roles/jumbotron/files/irssi.config | 286 | ||||
-rw-r--r-- | roles/jumbotron/meta/main.yml | 6 | ||||
-rw-r--r-- | roles/jumbotron/tasks/autologin.yml | 32 | ||||
-rw-r--r-- | roles/jumbotron/tasks/console.yml | 35 | ||||
-rw-r--r-- | roles/jumbotron/tasks/irssi.yml | 35 | ||||
-rw-r--r-- | roles/jumbotron/tasks/jumbotron.yml | 37 | ||||
-rw-r--r-- | roles/jumbotron/tasks/main.yml | 42 | ||||
-rw-r--r-- | roles/jumbotron/vars/main.yml | 28 |
15 files changed, 532 insertions, 0 deletions
@@ -1 +1,2 @@ space.labitat.dk +jumbotron.s diff --git a/jumbotron.yml b/jumbotron.yml new file mode 100644 index 0000000..666465c --- /dev/null +++ b/jumbotron.yml @@ -0,0 +1,11 @@ +--- +- hosts: jumbotron.s + pre_tasks: + - name: Detect chroot + set_fact: + chroot: "{{ ansible_connection == 'chroot' or 'container' in ansible_env }}" + tags: always + roles: + - jumbotron + +# vim: set ts=2 sw=2 et: diff --git a/roles/jumbotron/files/autologin b/roles/jumbotron/files/autologin new file mode 100644 index 0000000..f03f733 --- /dev/null +++ b/roles/jumbotron/files/autologin @@ -0,0 +1,3 @@ +#!/bin/bash + +exec irssi diff --git a/roles/jumbotron/files/bash_profile b/roles/jumbotron/files/bash_profile new file mode 100644 index 0000000..a473f85 --- /dev/null +++ b/roles/jumbotron/files/bash_profile @@ -0,0 +1,5 @@ +if [[ "$(tty)" = '/dev/tty1' ]]; then + exec "$HOME/.autologin" +fi + +. "$HOME/.bashrc" diff --git a/roles/jumbotron/files/eth0.network b/roles/jumbotron/files/eth0.network new file mode 100644 index 0000000..3e351ea --- /dev/null +++ b/roles/jumbotron/files/eth0.network @@ -0,0 +1,6 @@ +[Match] +Name=eth0 + +[Network] +DHCP=yes +IPv6AcceptRA=yes diff --git a/roles/jumbotron/files/getty@tty1.service.d/autologin.conf b/roles/jumbotron/files/getty@tty1.service.d/autologin.conf new file mode 100644 index 0000000..6b0f2f1 --- /dev/null +++ b/roles/jumbotron/files/getty@tty1.service.d/autologin.conf @@ -0,0 +1,3 @@ +[Service] +ExecStart= +ExecStart=-/sbin/agetty --autologin jumbotron --noclear %I $TERM diff --git a/roles/jumbotron/files/getty@tty1.service.d/noclear.conf b/roles/jumbotron/files/getty@tty1.service.d/noclear.conf new file mode 100644 index 0000000..52671c7 --- /dev/null +++ b/roles/jumbotron/files/getty@tty1.service.d/noclear.conf @@ -0,0 +1,2 @@ +[Service] +TTYVTDisallocate=no diff --git a/roles/jumbotron/files/irssi.config b/roles/jumbotron/files/irssi.config new file mode 100644 index 0000000..8530f7d --- /dev/null +++ b/roles/jumbotron/files/irssi.config @@ -0,0 +1,286 @@ +chatnets = { + Labitat = { type = "IRC"; }; +}; + +servers = ( + { + chatnet = "labitat"; + address = "labitat.dk"; + port = "6697"; + use_tls = "yes"; + autoconnect = "yes"; + } +); + +channels = ( + { + name = "#labitat"; + chatnet = "Labitat"; + autojoin = "yes"; + autosendcmd = "window 2"; + } +); + +aliases = { + ATAG = "WINDOW SERVER"; + ADDALLCHANS = "SCRIPT EXEC foreach my \\$channel (Irssi::channels()) { Irssi::command(\"CHANNEL ADD -auto \\$channel->{name} \\$channel->{server}->{tag} \\$channel->{key}\")\\;}"; + B = "BAN"; + BACK = "AWAY"; + BANS = "BAN"; + BYE = "QUIT"; + C = "CLEAR"; + CALC = "EXEC - if command -v bc >/dev/null 2>&1\\; then printf '%s=' '$*'\\; echo '$*' | bc -l\\; else echo bc was not found\\; fi"; + CHAT = "DCC CHAT"; + CUBES = "SCRIPT EXEC Irssi::active_win->print(\"%_bases\", MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print( do { join '', map { \"%x0\\${_}0\\$_\" } '0'..'9','A'..'F' }, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print(\"%_cubes\", MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print( do { my \\$y = \\$_*6 \\; join '', map { my \\$x = \\$_ \\; map { \"%x\\$x\\$_\\$x\\$_\" } @{['0'..'9','A'..'Z']}[\\$y .. \\$y+5] } 1..6 }, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) for 0..5 \\; Irssi::active_win->print(\"%_grays\", MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print( do { join '', map { \"%x7\\${_}7\\$_\" } 'A'..'X' }, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print(\"%_mIRC extended colours\", MSGLEVEL_CLIENTCRAP) \\; my \\$x \\; \\$x .= sprintf \"\00399,%02d%02d\",\\$_,\\$_ for 0..15 \\; Irssi::active_win->print(\\$x, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) \\; for my \\$z (0..6) { my \\$x \\; \\$x .= sprintf \"\00399,%02d%02d\",\\$_,\\$_ for 16+(\\$z*12)..16+(\\$z*12)+11 \\; Irssi::active_win->print(\\$x, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) }"; + DATE = "TIME"; + DEHIGHLIGHT = "DEHILIGHT"; + DESCRIBE = "ACTION"; + DHL = "DEHILIGHT"; + EXEMPTLIST = "MODE $C +e"; + EXIT = "QUIT"; + GOTO = "SCROLLBACK GOTO"; + HIGHLIGHT = "HILIGHT"; + HL = "HILIGHT"; + HOST = "USERHOST"; + INVITELIST = "MODE $C +I"; + J = "JOIN"; + K = "KICK"; + KB = "KICKBAN"; + KN = "KNOCKOUT"; + LAST = "LASTLOG"; + LEAVE = "PART"; + M = "MSG"; + MUB = "UNBAN *"; + N = "NAMES"; + NMSG = "^MSG"; + P = "PART"; + Q = "QUERY"; + RESET = "SET -default"; + RUN = "SCRIPT LOAD"; + SAY = "MSG *"; + SB = "SCROLLBACK"; + SBAR = "STATUSBAR"; + SIGNOFF = "QUIT"; + SV = "MSG * Irssi $J ($V) - http://www.irssi.org"; + T = "TOPIC"; + UB = "UNBAN"; + UMODE = "MODE $N"; + UNSET = "SET -clear"; + W = "WHO"; + WC = "WINDOW CLOSE"; + WG = "WINDOW GOTO"; + WJOIN = "JOIN -window"; + WI = "WHOIS"; + WII = "WHOIS $0 $0"; + WL = "WINDOW LIST"; + WN = "WINDOW NEW HIDDEN"; + WQUERY = "QUERY -window"; + WW = "WHOWAS"; + 1 = "WINDOW GOTO 1"; + 2 = "WINDOW GOTO 2"; + 3 = "WINDOW GOTO 3"; + 4 = "WINDOW GOTO 4"; + 5 = "WINDOW GOTO 5"; + 6 = "WINDOW GOTO 6"; + 7 = "WINDOW GOTO 7"; + 8 = "WINDOW GOTO 8"; + 9 = "WINDOW GOTO 9"; + 10 = "WINDOW GOTO 10"; + 11 = "WINDOW GOTO 11"; + 12 = "WINDOW GOTO 12"; + 13 = "WINDOW GOTO 13"; + 14 = "WINDOW GOTO 14"; + 15 = "WINDOW GOTO 15"; + 16 = "WINDOW GOTO 16"; + 17 = "WINDOW GOTO 17"; + 18 = "WINDOW GOTO 18"; + 19 = "WINDOW GOTO 19"; + 20 = "WINDOW GOTO 20"; + 21 = "WINDOW GOTO 21"; + 22 = "WINDOW GOTO 22"; + 23 = "WINDOW GOTO 23"; + 24 = "WINDOW GOTO 24"; + 25 = "WINDOW GOTO 25"; + 26 = "WINDOW GOTO 26"; + 27 = "WINDOW GOTO 27"; + 28 = "WINDOW GOTO 28"; + 29 = "WINDOW GOTO 29"; + 30 = "WINDOW GOTO 30"; + 31 = "WINDOW GOTO 31"; + 32 = "WINDOW GOTO 32"; + 33 = "WINDOW GOTO 33"; + 34 = "WINDOW GOTO 34"; + 35 = "WINDOW GOTO 35"; + 36 = "WINDOW GOTO 36"; + 37 = "WINDOW GOTO 37"; + 38 = "WINDOW GOTO 38"; + 39 = "WINDOW GOTO 39"; + 40 = "WINDOW GOTO 40"; + 41 = "WINDOW GOTO 41"; + 42 = "WINDOW GOTO 42"; + 43 = "WINDOW GOTO 43"; + 44 = "WINDOW GOTO 44"; + 45 = "WINDOW GOTO 45"; + 46 = "WINDOW GOTO 46"; + 47 = "WINDOW GOTO 47"; + 48 = "WINDOW GOTO 48"; + 49 = "WINDOW GOTO 49"; + 50 = "WINDOW GOTO 50"; + 51 = "WINDOW GOTO 51"; + 52 = "WINDOW GOTO 52"; + 53 = "WINDOW GOTO 53"; + 54 = "WINDOW GOTO 54"; + 55 = "WINDOW GOTO 55"; + 56 = "WINDOW GOTO 56"; + 57 = "WINDOW GOTO 57"; + 58 = "WINDOW GOTO 58"; + 59 = "WINDOW GOTO 59"; + 60 = "WINDOW GOTO 60"; + 61 = "WINDOW GOTO 61"; + 62 = "WINDOW GOTO 62"; + 63 = "WINDOW GOTO 63"; + 64 = "WINDOW GOTO 64"; + 65 = "WINDOW GOTO 65"; + 66 = "WINDOW GOTO 66"; + 67 = "WINDOW GOTO 67"; + 68 = "WINDOW GOTO 68"; + 69 = "WINDOW GOTO 69"; + 70 = "WINDOW GOTO 70"; + 71 = "WINDOW GOTO 71"; + 72 = "WINDOW GOTO 72"; + 73 = "WINDOW GOTO 73"; + 74 = "WINDOW GOTO 74"; + 75 = "WINDOW GOTO 75"; + 76 = "WINDOW GOTO 76"; + 77 = "WINDOW GOTO 77"; + 78 = "WINDOW GOTO 78"; + 79 = "WINDOW GOTO 79"; + 80 = "WINDOW GOTO 80"; + 81 = "WINDOW GOTO 81"; + 82 = "WINDOW GOTO 82"; + 83 = "WINDOW GOTO 83"; + 84 = "WINDOW GOTO 84"; + 85 = "WINDOW GOTO 85"; + 86 = "WINDOW GOTO 86"; + 87 = "WINDOW GOTO 87"; + 88 = "WINDOW GOTO 88"; + 89 = "WINDOW GOTO 89"; + 90 = "WINDOW GOTO 90"; + 91 = "WINDOW GOTO 91"; + 92 = "WINDOW GOTO 92"; + 93 = "WINDOW GOTO 93"; + 94 = "WINDOW GOTO 94"; + 95 = "WINDOW GOTO 95"; + 96 = "WINDOW GOTO 96"; + 97 = "WINDOW GOTO 97"; + 98 = "WINDOW GOTO 98"; + 99 = "WINDOW GOTO 99"; +}; + +statusbar = { + + items = { + + barstart = "{sbstart}"; + barend = "{sbend}"; + + topicbarstart = "{topicsbstart}"; + topicbarend = "{topicsbend}"; + + time = "{sb $Z}"; + user = "{sb {sbnickmode $cumode}$N{sbmode $usermode}{sbaway $A}}"; + + window = "{sb $winref:$tag/$itemname{sbmode $M}}"; + window_empty = "{sb $winref{sbservertag $tag}}"; + + prompt = "{prompt $[.15]itemname}"; + prompt_empty = "{prompt $winname}"; + + topic = " $topic"; + topic_empty = " Irssi v$J - http://www.irssi.org"; + + lag = "{sb Lag: $0-}"; + act = "{sb Act: $0-}"; + more = "-- more --"; + }; + + default = { + + window = { + + disabled = "no"; + type = "window"; + placement = "bottom"; + position = "1"; + visible = "active"; + + items = { + barstart = { priority = "100"; }; + time = { }; + user = { }; + window = { }; + window_empty = { }; + lag = { priority = "-1"; }; + act = { priority = "10"; }; + more = { priority = "-1"; alignment = "right"; }; + barend = { priority = "100"; alignment = "right"; }; + }; + }; + + window_inact = { + + type = "window"; + placement = "bottom"; + position = "1"; + visible = "inactive"; + + items = { + barstart = { priority = "100"; }; + window = { }; + window_empty = { }; + more = { priority = "-1"; alignment = "right"; }; + barend = { priority = "100"; alignment = "right"; }; + }; + }; + + prompt = { + + type = "root"; + placement = "bottom"; + position = "100"; + visible = "always"; + + items = { + prompt = { priority = "-1"; }; + prompt_empty = { priority = "-1"; }; + input = { priority = "10"; }; + }; + }; + + topic = { + + type = "root"; + placement = "top"; + position = "1"; + visible = "always"; + + items = { + topicbarstart = { priority = "100"; }; + topic = { }; + topic_empty = { }; + topicbarend = { priority = "100"; alignment = "right"; }; + }; + }; + }; +}; +settings = { + core = { + real_name = "John Jumbotron"; + user_name = "jumbotron"; + nick = "Jumbotron"; + recode_out_default_charset = "utf8"; + recode_fallback = "ISO-8859-15"; + + }; + "fe-text" = { actlist_sort = "refnum"; }; +}; diff --git a/roles/jumbotron/meta/main.yml b/roles/jumbotron/meta/main.yml new file mode 100644 index 0000000..731a8f2 --- /dev/null +++ b/roles/jumbotron/meta/main.yml @@ -0,0 +1,6 @@ +--- +dependencies: +- role: raspbian +- role: users + +# vim: set ts=2 sw=2 et: diff --git a/roles/jumbotron/tasks/autologin.yml b/roles/jumbotron/tasks/autologin.yml new file mode 100644 index 0000000..f9052ba --- /dev/null +++ b/roles/jumbotron/tasks/autologin.yml @@ -0,0 +1,32 @@ +--- +- name: Make sure getty@tty1.service.d exists + file: + path: '/etc/systemd/system/getty@tty1.service.d' + state: directory + owner: root + group: root + mode: 0755 + +- name: Register existing getty@tty1 config + find: + paths: '/etc/systemd/system/getty@tty1.service.d/' + register: getty_tty1_existing + +- name: Autologin jumbotron on tty1 + copy: + dest: '/etc/systemd/system/getty@tty1.service.d/' + src: '{{ item }}' + owner: root + group: root + mode: 0644 + with_fileglob: 'getty@tty1.service.d/*' + register: getty_tty1_created + +- name: Delete unneeded tty1 configuration + file: + path: '{{ item }}' + state: absent + with_items: "{{ getty_tty1_existing.files|map(attribute='path')|list }}" + when: "item not in getty_tty1_created.results|map(attribute='dest')" + +# vim: set ts=2 sw=2 et: diff --git a/roles/jumbotron/tasks/console.yml b/roles/jumbotron/tasks/console.yml new file mode 100644 index 0000000..55ede76 --- /dev/null +++ b/roles/jumbotron/tasks/console.yml @@ -0,0 +1,35 @@ +--- +- name: Configure VGA output + lineinfile: + path: '/boot/config.txt' + regexp: "^{{ item.rsplit('=', 1)[0] }}=" + line: '{{ item }}' + with_items: + - 'dtoverlay=vga666' + - 'enable_dpi_lcd=1' + - 'display_default_lcd=1' + - 'dpi_group=2' + - 'dpi_mode=35' + - 'dtparam=spi=off' + - 'dtparam=i2c_arm=off' + +- name: Configure console font + lineinfile: + path: '/etc/default/console-setup' + regexp: "^{{ item.split('=', 1)[0] }}=" + line: '{{ item }}' + with_items: + - 'CHARMAP="UTF-8"' + - 'CODESET="Lat15"' + - 'FONTFACE="Terminus"' + - 'FONTSIZE="32x16"' + +- name: Configure console keyboard + lineinfile: + path: '/etc/default/keyboard' + regexp: "^{{ item.split('=', 1)[0] }}=" + line: '{{ item }}' + with_items: + - 'XKBLAYOUT="dk"' + +# vim: set ts=2 sw=2 et: diff --git a/roles/jumbotron/tasks/irssi.yml b/roles/jumbotron/tasks/irssi.yml new file mode 100644 index 0000000..d3dd003 --- /dev/null +++ b/roles/jumbotron/tasks/irssi.yml @@ -0,0 +1,35 @@ +--- +- name: Install irssi + apt: + name: irssi + state: present + tags: + - packages + +- name: Make sure ~jumbotron/.irssi exists + file: + path: '~jumbotron/{{ item }}' + state: directory + owner: jumbotron + group: users + mode: 0755 + with_items: + - .irssi + - .irssi/scripts + - .irssi/scripts/autorun + +- name: Configure irssi + copy: + dest: '~jumbotron/.irssi/config' + src: 'irssi.config' + owner: jumbotron + group: users + mode: 0644 + +- name: Add bot-script + file: + path: '~jumbotron/.irssi/scripts/autorun/jumbowatch.pl' + src: '../../../jumbotron/jumbowatch.pl' + state: link + +# vim: set ts=2 sw=2 et: diff --git a/roles/jumbotron/tasks/jumbotron.yml b/roles/jumbotron/tasks/jumbotron.yml new file mode 100644 index 0000000..0b6f1a7 --- /dev/null +++ b/roles/jumbotron/tasks/jumbotron.yml @@ -0,0 +1,37 @@ +--- +- name: Create jumbotron user + user: + comment: 'John Jumbotron' + name: jumbotron + shell: '/bin/bash' + uid: 3000 + group: users + +- name: Create jumbotron dotfiles + copy: + dest: '~jumbotron/.{{ item.name }}' + src: '{{ item.name }}' + owner: jumbotron + group: users + mode: '{{ item.mode }}' + with_items: + - { name: bash_profile, mode: 0o644 } + - { name: autologin, mode: 0o755 } + +- name: Check out jumbotron repo + git: + dest: '~jumbotron/jumbotron' + repo: 'https://github.com/labitat/jumbotron.git' + accept_hostkey: yes + clone: yes + update: yes + remote: origin + +- name: Make sure jumbotron owns git repo + file: + dest: '~jumbotron/jumbotron' + owner: jumbotron + group: users + recurse: yes + +# vim: set ts=2 sw=2 et: diff --git a/roles/jumbotron/tasks/main.yml b/roles/jumbotron/tasks/main.yml new file mode 100644 index 0000000..e7c45a8 --- /dev/null +++ b/roles/jumbotron/tasks/main.yml @@ -0,0 +1,42 @@ +--- +- name: Install network configuration + copy: + dest: '/etc/systemd/network/10-eth0.network' + src: eth0.network + owner: root + group: root + mode: 0644 + tags: + - networkd-config + +- name: Disable unused services + systemd: + name: '{{ item }}' + enabled: no + with_items: + - hciuart.service + - remote-fs.target + - rsync.service + - bluetooth.service + tags: + - systemd + +- name: Remove broken service links + file: + path: '{{ item }}' + state: absent + with_items: + - /etc/systemd/system/bluetooth.target.wants + tags: + - systemd + +- import_tasks: console.yml + tags: console +- import_tasks: jumbotron.yml + tags: jumbotron +- import_tasks: autologin.yml + tags: autologin +- import_tasks: irssi.yml + tags: irssi + +# vim: set ts=2 sw=2 et: diff --git a/roles/jumbotron/vars/main.yml b/roles/jumbotron/vars/main.yml new file mode 100644 index 0000000..f1a105d --- /dev/null +++ b/roles/jumbotron/vars/main.yml @@ -0,0 +1,28 @@ +--- +hostname: 'jumbotron' + +resolved_conf: + 'Resolve.DNSSEC': 'yes' + +apt_sources: + raspbian: + components: + - main + - contrib + - no-free + - rpi + +apt_packages: + 'logrotate': absent + 'cron': absent + + 'git': present # to check out jumbotron repo + 'wiringpi': present # for jumbotron_ping script + 'console-setup': present # for proper console font/keyboard + 'irssi': present + + # jumbowatch.pl dependencies + 'libjson-perl': present + 'libwww-perl': present + +# vim: set ts=2 sw=2 et: |