Google CTF begginers quest – wrażenia

O Google CTF dowiedziałem się zupełnym przypadkiem, prawdopodobnie info mignęło mi na Twitterze. Do głównego nie podchodziłem i z braku czasu, i umiejętności. Jednak stwierdziłem w sobotę, że pobawię się chociaż zadaniami dla początkujących przy kawie, czyli begginers quest. Pierwsze wrażenie jak najbardziej pozytywne, jest fabuła, jest estetyczna strona.

Google CTF screenshot
Google CTF screenshot – poza ostatnim dolnym te zadania albo umiałem rozwiązać, albo bardzo niewiele zabrakło

Zadanie pierwsze (letter) trywialne, zadanie drugie (floppy) też poszło szybko i… się wciągnąłęm. Zadanie trzecie (JS safe) już nie takie proste. Tzn. niby widzę o co chodzi, ale JS to nie moja działka, więc próbuję innej ścieżki. Na warsztat poszło zadanie z dolnej ścieżki (moar) i… wpadłem w mailny, niepotrzebnie walcząc z socat zamiast przejść do sedna. TBH zmyliło mnie zepsute wyświetlanie i liczyłem, że flaga będzie po prostu gdzieś w manualu, jak tylko naprawię wyświetlanie, tj. połączę się przy pomocy socat zamiast nc. Żeby było śmieszniej o prawidłowym rozwiązaniu też pomyślałem, ale… zafiksowałem się na tym, że najpierw wymagany jest socat i nie drążyłem tematu.

Postanowiłem zajrzeć w górną ścieżkę i… bingo, pierwsze zadanie (OCR is cool) wygląda na proste. Najwięcej czasu zeszło mi na OCR. Dda się znaleźć sensowne online, niemniej jak potem testowałem to najlepiej od kopa działał lios. Kolejne zadania idą dość szybko, choć nie zawsze do końca ortodoksyjnie. Utknąłem dopiero na Media DB. Oczywiście prawidłowo rozpoznałem i typ, i miejsce, gdzie jest luka ale… Zabrakło skilla, a w przykładach w sieci dominuje PHP, MySQL i… nieco inne payloady, niż wymagany. Jak się później okazało, chciałem to zrobić w sposób mocno przekombinowany. Chwilę powalczyłem, ale nie wiedząc, czy specyfika Pythona, czy SQLite, odpuściłem, robiąc finalnie sześć zadań.

Przyznaję, że CTF bardzo mi się podobał. Niestety trochę słabo z czasem stałem, poza tym, to jedna z pierwszych tego typu zabaw. Chociaż z tego co pamiętam w jakieś podobne zagadki kiedyś się okazjonalnie bawiłem. Przy czym może nie do końca się to CTF nazywało i bardziej związane ze steganografią były. Klimat nieco podobny jak przy konkursach związanych z programowaniem, choć tu się bardziej psuje/debuguje, niż tworzy. 😉

Tak czy inaczej polecam zabawę, jeśli ktoś ma chwilę. Przez jakiś czas serwis powinien jeszcze działać, choć nie jest już supportowany, można się pobawić (dlatego bez spoilerów). Bardzo staranne przygotowanie, choć zadania trochę trudne, jak dla początkujących i bardzo przekrojowe.

Jeśli komuś się znudzi, albo po prostu utknie, to Gynvael pokazywał na YouTube rozwiązanie wszystkich zadań z Google CTF dla początkujących na żywo. Jest podział na zadania, można przeskoczyć do wybranego, co się przydaje, bo materiału trwa prawie cztery godziny.

Co do samego streamu mam mieszane uczucia. Z jednej strony bardzo fajnie i live, z drugiej trochę chaosu i momentami dłużyzn. Ale takie są uroki rozwiązywania na żywo. Za to jest klimat i wytłumaczenie okolic i przyległości. Gdyby coś było za szybko lub niezrozumiałe, to materiały powinny już być na GitHubie. Zatem ostatecznie polecam, tym bardziej, że nie kojarzę innego miejsca z kompletem rozwiązań.

Okazało się, że brakuje mi porządnego deassemblera. Moje hexedytory też nie do końca spełniają oczekiwania (lub nie umiem ich sprawnie używać). Ale przede wszystkim muszę dojść do porozumienia z terminalem, bo w zadaniu Fridge TODO list zamiast bannera widzę krzaki. I szczerze mówiąc myślałem, że pozbycie się ich to część zadania, dopiero ww. stream pokazał, że zupełnie nie o to chodzi… 😉

UPDATE: Tu znajdziesz wpis o Google CTF 2019.

Spis wyborców a rejestr wyborców

Człowiek uczy się całe życie. Czasem nawet patrzy i nie widzi. Jakiś czas temu opisywałem głosowanie poza miejscem stałego zameldowania w kontekście wyborów samorządowych. Nawet pomarudziłem, że dużo roboty, w porównaniu z wyborami parlamentarnymi. Tymczasem przeoczyłem słowo rejestr, które się tam pojawia, zamiast słowa spis, które pojawia się zwykle przy wyborach parlamentarnych itp. W innym moim wpisie użyłem w ogóle słowa lista, które też potocznie jest synonimem spisu czy rejestru, ale w prawie w ogóle nie występuje.

Postanowiłem więc przybliżyć różnice między spisem wyborców a rejestrem wyborców, czyli zupełnie innym tworem. Wszystkie procedury opisuje dokładnie w Kodeks Wyborczy (link do tekstu jednolitego jest w linkach zewnętrznych), w razie wątpliwości odsyłam tam, tu będzie tylko skrót. Zaznaczam, że nie jestem prawnikiem, więc pewne niuanse

Dopisanie do spisu wyborców

  • Określa je art. 28 Kodeksu Wyborczego,
  • Dokonuje się go w urzędzie gminy w miejscu czasowego pobytu,
  • Jest proste – wystarczy wypełnić formularz i okazać dokument potwierdzający tożsamość,
  • Jest jednorazowe, tj. działa tylko na konkretne wybory. Czyli jest tymczasowe.

Dopisanie do rejestru wyborców

  • Określa je art. 19 Kodeksu Wyborczego,
  • Również dokonuje się go w urzędzie gminy w miejscu stałego pobytu,
  • Jest nieco bardziej skomplikowane – dwa formularze, konieczność wykazania stałości pobytu (zaświadczenie z miejsca pracy, umowa najmu, akt własności/nr księgi wieczystej)
  • Działa na stałe – zostajemy wykreśleni z rejestru w miejscu stałego zameldowania i wpisani do rejestru wyborców tam, gdzie złożyliśmy wniosek. Czyli jest stałe.

No i pora na zadanie praktyczne, czyli mały hacking systemu, albo lifehack (zależy jak patrzeć). Zagadnienie, od którego rozpoczęła się dyskusja na FB to:

Czy można, będąc zameldowanym na stałe w Przemyślu, mieszkając na stałe w Szczecinie, pobrać – bez wyprawy do Przemyśla, czyli w szczecińskim urzędzie miasta – zaświadczenie, uprawniające do głosowania w Warszawie?

Wygląda, że da się to zrobić (rozwiązanie nie jest wymyślone przeze mnie), ale trzeba rozpocząć rozpoczniemy operację odpowiednio wcześniej:

  1. Dopisujemy się do rejestru wyborców w Szczecinie (wykazujemy, że mieszkamy tam na stałe itp.).
  2. Po pomyślnym dopisaniu do rejestru wyborców, udajemy się do urzędu miasta w Szczecinie i informujemy, że chcemy zaświadczenie uprawniające do głosowania poza miejscem zamieszkania (art. 32 Kodeksu Wyborczego).
  3. [solved] 🙂