aboutsummaryrefslogtreecommitdiff
path: root/Västgöta/webbsida.wiki
blob: 59c0296ec147e688087e7ab3bf01fa19ae95701a (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
= Server =

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

- Ubuntu 18.04 LTS.
- Wordpress genom pakethanteraren, dock med vissa ombyggningar.
- Nginx för HTTP

== Användarkonton ==
Varje person som har något att göra på (från Unix-sidan) ska ha ett
eget användarkonto. De bör även läggas till i gruppen vastgota (1004)
för att kunna komma åt rimliga filer.

{{{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 =
- 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.

= Kalender =
:todo:

Nuvarande har problem

https://git.hornquist.se/vg-cal

- Visas på lämpligt sätt
- VCalendar/.ics nedladdning
- Manuellt tillagda events.
- Auto-hantering av ansvariga

== Events Manager ==
http://wp-events-plugin.com/

Den vi använder.

Den helt klart bästa. Tillhandahåller upprepade events.
Saknar lite när det kommer till användarvänlighet samt display, men
det går nog att lösa på sikt.

Har även ett bokningssystem i sig, oklart huruvida man kan låta vem
som skapa ny bokning, eller om det bara är för att anmäla sig till
events som finns.

== Events Calendar ==
https://theeventscalendar.com/

Helt byggd kring events, och inte återkommande events. Har dessutom en
jobbig licensmodell.

== Booking Calendar ==
https://wpbookingcalendar.com/

Med tillägget Booking Manager

Ser bra ut, men har inte heller stöd för upprepande events. Påstår sig
ha möjlighet att importera ICS strömmar, men verkar skapa en sepparat
bokning då.

= WP cli =
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
}}}

==== Några resurser ====
- https://codex.wordpress.org/Post_to_your_blog_using_email
- https://developer.wordpress.org/reference/functions/wp_insert_post/
- https://github.com/TheFox/smtpd

    - [X] Läggs `[Västgöta Nation]` automatiskt till i brevhuvud? NEJ