aboutsummaryrefslogtreecommitdiff
path: root/Västgöta/webbsida.wiki
blob: 3625b712ef8e3256368248420def74ab7f254881 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
= Server =

== Kvar att dokumentera ==
- [ ] Puppet-instalation

== Framtida att göra ==
- [ ] Ldap-server för
    - [ ] Styrelseposter
    - [ ] Medlemsregister

--------------------------------------------------

http://vastgota.nation.liu.se

Det här är den officiella dokumentationen över hur Västgöta Nation i
Linköpings webbsida fungerar.

Sidor hostas av Lysator mailto:root@lysator.liu.se

- Debian 11
- Wordpress genom pakethanteraren
- Nginx för HTTP

== Kataloger ==
`/srv/styrelse` :: Delade filer för styrelsemedlemmar
`/srv/stupan-backup` :: Säkerhetskoppiering från stupan, se [[#Systemkonton]]

== Epost ==
Servern kör en skapligt standard postfix-installation, tillsamans med
dovecot för IMAP-access.

E-postlistor administreras i filen `/etc/aliases`. Kom ihåg att köra
`newaliases` efter ändringar där.

Varje konto vilken ska kunna ta emot epost behöver en katalog
`~/Maildir`, samt tillåtas på Lysators mailserver.

För att läsa och skicka e-post, anslut med extern klient enligt
[[mail]]

== Användarkonton ==
Konton är alla Unix-konton i botten.
Varje styrelsepost har ett eget konto, övriga personkonton kan finnas.

=== Användare ===

`passwd _username_` :: Byt löserord på konto
`usermod -c "_Förnamn Efternamn_" _username_` :: Uppdatera "verkligt" namn på konto
`usermod -aG sudo _username_` :: Ge användare root-rättigheter
`gpasswd -d _username_ sudo` :: Ta bort root-rättigheter från användare

==== Postspecifika konton ====
aktivitet      :: 1001
info           :: 1002
intendent      :: 1003
kassor         :: 1004
lokal          :: 1005
medlem         :: 1006
pq             :: 1007
propaganda     :: 1008
qurator        :: 1009
sekreterare    :: 1010
guckel         :: 1011
valberedningen :: 1012

==== Systemkonton ====
stupan-backup :: 997
    :: Tar emot dagliga backups från Ättestupans dator

==== Övriga konton ====
lysroot :: 1000
    :: Lysators administratörskonto, får inte tas bort
rehnman :: 1013
    :: Betrodd person med root-rättigheter

=== Grupper ===
vastgota :: 1001
styrelse :: 1002

{{{sh
useradd -G vastgota <user>
}}}

= Webbsida =
http://vastgota.nation.liu.se/

Västgöta Nations webbsida kör för nuvarande Wordpress. Det temat som
körs (Blogeasy) är valt för att det var det som såg minnst skit ut.

== Design ==

{{{css class="right"
/* Fullständig CSS-listning */

.main-nav-bg,
.slicknav_menu {
	background-color: #FFe500;
}
.main-navigation a,
.slicknav_nav a {
	color: #100b08;
}
.main-navigation a:hover,
.slicknav_nav a:hover {
	color: #707070;
    
}
.sub-menu .menu-item {
	background-color: #FFe500;
}
.btn {
	background-color: #FFe500;
	border-color: #100b08;
	color: #100b08;
}

.site-footer {
	background-color: #ffe500;
	color: darkgrey;
}
.site-footer a {
	color: #100b08;
}
.site-footer a:hover {
	color: #707070;
}

#content a {
	color: blue;
}

#content a::visited {
	color: purple;
}

#content .entry-meta a {
	color: #002e5b;
}

#content header a {
	color: #002e5b;
}

#content aside a {
	color: #002e5b;
}

#content footer a {
	color: #002e5b;
}

#content a.btn {
	color: #100b08;
}

.datestr, .datesep {
	font-family: monospace;
}

td.eventful {
    background-color: #FFe500;
    border-radius: 20%;
}

td.eventful-today {
	border-radius: 20%;
}
}}}

För att få temat i stil med föreningen har nedan följande CSS lagts
till. Det den framförallt gör är att byta ut alla mörkblå element mot
Västgöta-gula (`#FFe500`).

Full CSS-listning till höger.

=== Förbättringar ===

Menyalternativ med barn markeras för nuvarande inte på
skrivbordsversionen av webbsidan (dock på mobilversionen). Någonting i
stil med följande bör användas.

{{{css
.menu-item-has-children > a:after {
	content: " V";
	font-size: 80%;
	color: red;
}
}}}

`.menu-item-has-children` är den interesanta biten.

== Karta ==
På https://vastgota.nation.liu.se/attestupan/ finns en karta till
stupan. I skrivandets stund använder den
[[https://leafletjs.com/|LeafletJS]] vilket bygger på
[[https://www.openstreetmap.org/|OpenStreetMap]].


== Ansvariga för Stupan ==

Ett minde PHP-tillägg finns också (se nedan). Vilket kör genom "Code
Snippets" pluginet. Koden kan, vid behov, portas till annat format
utan större besvär. Dock är den inget vidare.

Det lägger till shortcoden `[ansvariga]`, vilket ger en
lista på ansvariga för Stupan. Informationen fås från filen
`/etc/vastgota/ansvariga`, och är på formen:
{{{
2018-10-12 Hugo
}}}
Altså ISO-8601 datum, följt av ett mellanslag och ett namn. Mellanslag
får förekomma i namnet. Rader som börjar med `#` är kommentarer, end
of line kommentarer stödjs inte.

Shortcoden tar ett argument, `back`, vilket är hur många veckor backåt
mistorik ska visas. Om inget argument ges visas full historik. På
ättestupans webbsida visas historik fyra veckor bakåt, samt så länkas
det till en sida med full historik.

=== ICal ===
Det finns också ett python-script (listat nedan) vilket läser igenom
filen och dumpar ut det till en icalendar blob. Tyvärr kör den inte
för nuvarande för att servern inte hade något bra sätt att integrera
godtyckliga script.

=== Kommentar från /etc/vastgota/ansvariga ===
{{{sh
# The following is a list of people responsible for Ättestupan.
# Each line should contain an ISO-8601 formatted date (YYYY-MM-DD),
# followed by a space and finally any number of characters which make
# out the name.
# Entries should be placed in chronological order.
# Refrain from deleting old entries unless totally necessary.
}}}

=== Text till webbsida ===
https://vastgota.nation.liu.se/attestupan/ansvariga/

Just nu står det

    Vi behöver inget snöre

Jag tror det duger bra.

=== Kodlistning ===

{{{php
<?php
add_shortcode( 'ansvariga', function ($atts) {
  $a = shortcode_atts( array(
	"back" => 0
	), $atts);

  if ($a["back"] == 0) {
	$back = false;
  } else {
  	$back = strtotime("-". $a["back"] . " weeks");
  }

  $retstr = "";
  $retstr .= "<ul>";
  $ansvariga = array();
  $contents = file_get_contents("/etc/vastgota/ansvariga");
  $lines = explode("\n", $contents);
  foreach ($lines as $row => $data) {
    if ($data == "") continue;
	if ($data[0] == "#") continue;
    $row_data = explode(" ", $data, 2);
    $ansvariga[$row_data[0]] = $row_data[1];
  }

  $now = time();
  foreach ($ansvariga as $datestr => $person) {
    // We compare with the day after since they are responsible for the evening.
    $then = strtotime($datestr) + 3600 * 24;
	if ($back != 0 && $then < $back) continue;
    $retstr .= "<li>";
    if ($now > $then) { $retstr .= "<del>"; }
    $retstr .= "<span class='datestr'>$datestr</span> <span class='datesep'>::</span> <span class='dateper'>$person</span>";
    if ($now > $then) { $retstr .= "</del>"; }
    $retstr .= "</li>";
  }
  $retstr .= "</ul>";
  return $retstr;
} );
}}}

{{{python
#!/usr/bin/env python3

# Simple program for generating a vcalendar of people responssible for
# Ättestupan. Runs as a CGI script.
# TODO Currently doesn't check that a line doesn't contain more that
# 75 octets.

vcal_fmt = """BEGIN:VCALENDAR
VERSION:2.0
PRODID:-//Västgöta Nation/2.0/
{}
END:VCALENDAR"""

vevent_fmt = """BEGIN:VEVENT
UID:vg_ansvarig_{date}@vastgota.nation.liu.se
DTSTART:{date}T190000
DTEND:{date}T220000
SUMMARY:Stupan: {ansvarig} ans.
END:VEVENT
"""

# Should DTSTAMP be added, should signal when the event was created,
# which I can probably just set to the generation time (running time
# of this script)k

def get_vcalendar(ansvarig_file):
    """
    Returns a string containing a vcalendar of all people
    responsible.
    """
    str = ""
    with open(ansvarig_file, "r") as f:
        for line in f:
            line = line.replace("\n", "")
            if not line: continue
            if line[0] == "#": continue

            date, ansvarig = line.split(" ", 1)
            str += vevent_fmt.format(date=date.replace("-", ""), ansvarig=ansvarig)

    return vcal_fmt.format(str).replace("\n", "\r\n")

def get_header():
    return """HTTP/1.1
Connection: Close
Content-type: text/calendar
"""

if __name__ == "__main__":
    print(get_header())
    print(get_vcalendar("/etc/vastgota/ansvariga"))
}}}

---------------

All kod på den här sidan är manuellt inklippt. Skillnader från det som
faktiskt körs kan finnas.

= Skrivare =
- [[https://support.brother.com/g/b/downloadtop.aspx?c=se&lang=sv&prod=dcpl2520dw_us_eu|DCP-L2520 DW]]
- Bläck
  - Enligt Brother
    - TN-660
    - TN-630
  - Enligt CDON, på produkten
    - [[https://cdon.se/hushallsapparater/lasertoner-brother-tn-2310-p40388232|TN-2310]]

= Telefon =
- `*120#` för att visa abonemangsstatus.
ord

= WP cli =
*För nuvarande körs inte det här systemet*.

https://github.com/wp-cli/wp-cli
Installerat till `/usr/local/bin/wp`. I början av
`/usr/share/wordpress/wp-config.php`, precis efter `<?php` har
följande lagts till:

{{{php
if (defined ('WP_CLI') && WP_CLI && ! isset ($_SERVER['HTTP_HOST'])) {
	$_SERVER['HTTP_HOST'] = 'vastgota.lysator.liu.se';
}
}}}

python3-dateutil

{{{sh
wp post create \
    --post_author=1 \ # kör `wp user list` för att få id
    --post_date=2020-03-23 \
    --post_content="<pre>`cat file.txt`</pre>" \
    --post_title='Veckomail v.13' \
    --post_status=publish \
    --post_category=Veckomail
}}}

https://git.lysator.liu.se/hugo/wp-publish-by-email

= Veckbrev mailproxy =
:TODO:

Veckbrev bör automatiskt publiceras på webbsidan då de skickas till
listan... Uppnås troligen enklast genom att lägga till
publish@vastgota.lysator.liu.se (eller liknande) på listan, och låta
servern fånga upp det.

{{{
# /etc/postfix/relay/*_recipients
test@vastgota.lysator.liu.se OK

$ postmap vastgota_recipients
}}}