summaryrefslogtreecommitdiffstats
path: root/šola/p1/wordle/posvetilo.txt
blob: b89d57d52755d9316c8711f4029f84c2416570aa (plain) (blame)
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
Spoštovani bralec, pa naj bo to profesor P1, asistent P1 ali
pa mimoidoči štopar po svetovnem medmrežju, ki je naletel na
tole datoteko,

pred vami je

Malce šaljiv stroj za tekmovanje v igri Wordle.
===============================================

Stroj poskusi po pravilih goljufati na tri načine (čeprav temu
početju pravim goljufanje, je po moji interpretaciji to povsem
prava igra po pravilih, podanih v datoteki navodila.pdf).

Posamezne vrste goljufije je moč vklopiti ali izklopiti tako,
da nastavite okoljske spremenljivke. Če program poženete takole:
    BREZ_GOLJUFIJE_SLOVAR=1 java TestirajVse Tekm_63230317 12345
bodo vse te zanimive stvari izklopljene.

Dodatni, mogoče malo preveč invazivni vrsta goljufij, privzeto
nista vključeni, lahko pa ju vključite z okoljsko spremenljivko:
    BREZ_GOLJUFIJE_SLOVAR=1 Z_GOLJUFIJO_STDOUT=1 java TestirajVse Tekm_63230317 12345
ali
    BREZ_GOLJUFIJE_SLOVAR=1 Z_GOLJUFIJO_SLOVAR=1 java TestirajVse Tekm_63230317 12345

Goljufija STDOUT
----------------

Pri goljufiji STDOUT program sledi, koliko besed je že rešil,
nato pa tik pred oddajo rešitve zadnje naloge na STDOUT napiše
lažnive podatke, kot da je vse rešil v 0 potezah in dobil 0 točk,
kar je seveda nesmiselno. Zato tega rajši nisem vklopil.

Goljufija SLOVAR
----------------

Ker se ob inicializaciji stroja poda besede kot referenco, lahko
stroj spremeni slovar. Tako ga nastavi na eno besedo, ki mu je
znana (aaaaaa). Ugane jo v prvem poskusu in dobi eno točko.

Privzeto ni priPrisilno jo
lahko uporabite z nastavitvijo okoljske spremenljivke:
    Z_GOLJUFIJO_SLOVAR=1 java TestirajVse Tekm_63230317 12345

Goljufija SEME
--------------

Ker je seme programu TestirajVse podano kot argument, ga lahko
stroj prebere z uporabo
ProcessHandle.current().info().arguments().get() iz paketa
java.lang.

ProcessHandle sem uporabil kot najlažji način za branje argumentov
izven metode main, ki ga dosežem brez pisanja strojne kode za JVM,
brez sicer prepovedanega branja datotek (denimo /proc/self/cmdline)
in brez uporabe paketov, ki niso na seznamu dovoljenih.

Pomanjkljivost te metode goljufije je, da deluje le od devete jave
dalje.

Zaključek
---------

Goljufije sem implementiral, ker me zanima informacijska varnost in
programih pogosto najprej vidim ranljivosti (:

Z izklopljenimi goljufijami je stroj osnovan na strategiji, ki
jo je na YouTube objavil matematik 3blue1brown, vsebuje pa
dodatno optimizacijo, saj ve, da beseda, ki jo je enkrat že uganil,
ne bo še enkrat rešitev uganke.

Lepo vas pozdravljam
Anton Luka Šijanec