From 41dffd1b863787605fa121b0d0388ef10f5d8375 Mon Sep 17 00:00:00 2001 From: Jyri-Petteri Paloposki Date: Thu, 16 May 2019 19:08:20 +0300 Subject: [PATCH] #13: Adding a script for generating Nginx authentication for a game --- scripts/generate_passwords.py | 69 +++++++++++++++++++++++++++++++++++ web/settings.py | 11 ------ web/templates/tupa/base.html | 1 - web/templates/tupa/index.html | 2 +- web/templates/version.html | 2 - 5 files changed, 70 insertions(+), 15 deletions(-) create mode 100644 scripts/generate_passwords.py delete mode 100644 web/templates/version.html diff --git a/scripts/generate_passwords.py b/scripts/generate_passwords.py new file mode 100644 index 00000000..02cc58f5 --- /dev/null +++ b/scripts/generate_passwords.py @@ -0,0 +1,69 @@ +from shutil import copyfile +import string, random, crypt +import MySQLdb + +def find_check_ids_by_name(checks, cursor): + # execute SQL query using execute() method. + cursor.execute("SELECT id FROM kipa_tehtava WHERE sarja_id IN (26, 27, 28, 29, 30) AND nimi IN ('%s')" % "', '".join(checks)) + data = cursor.fetchall() + + res = [] + for row in data: + for val in row: + res.append(str(val)) + + return res + +prefix = 'llhk19-' +baseurl = '/kipa/Leon_lenkki_ja_Hilkan_kilpa_2019/' +accounts = { + "hamk": ["Tyoesuhdealias", "RistiNollaKorolla"], + "liikennepuisto": ["RushHour"], + "vanaja": ["HPK"], + "actionfactory": ["Action_Factory"], + "yo": ["Larry", "Hexed", "Escape_room", "Commodore_64", "Ruokaralli", "Kanaset", "Kummitusmetsae"], + "tekoaltaat": ["Scrabble"], + "kankaantausta": ["Super_Mario_suunnistusmaassa"], + "hameensanomat": ["Rubikin_kuutio"], + "jaahalli": ["Deja_vu"], + "linna": ["Risk", "Arvaa_kuka"], + "ahvenisto": ["Afrikan_taehti"], + "hakovuori": ["Laulava_muistipeli"], + "verkatehdas": ["Roskaviesti"] +} +templatefile = '/srv/django/kipa/passwords-llhk19' +path = '/srv/django/kipa/auth_files/llhk19/' +letters = string.ascii_letters + +access_config = '' + +db = MySQLdb.connect(user="USER", passwd="PASSWORD", host="localhost", db="DATABASE") +cursor = db.cursor() + +print(accounts) +for name, checks in accounts.items(): + username = prefix + name + pwdfile = path + name + password = ''.join(random.choice(letters) for i in range(10)) + pwhash = crypt.crypt(password) + copyfile(templatefile, pwdfile) + f = open(pwdfile, 'a') + print(username + ':' + pwhash, file=f) + print(username + ';' + password) + + ids = find_check_ids_by_name(checks, cursor) + for id in ids: + access_config = access_config + """ + location {baseurl}syota/tehtava/{id} {{ + auth_basic "Vain {name}-rastin tulosten syottajille"; + auth_basic_user_file "{pwdfile}"; + include uwsgi_params; + uwsgi_pass unix:/run/uwsgi/kipa.sock; + }} + + """.format(baseurl=baseurl, name=name.capitalize(), id=id, pwdfile=pwdfile) + +c = open(path + 'access.conf', 'w') +print(access_config, file=c) + +db.close() diff --git a/web/settings.py b/web/settings.py index 224142d1..ae068094 100644 --- a/web/settings.py +++ b/web/settings.py @@ -1,16 +1,5 @@ import os -import time -try : - fin = open("templates/version.html", "r") - revision_line=fin.readline() ; - fin.close() - fout = open("templates/version.html", "w") - fout.write( revision_line ) - fout.write( "{% comment %} " +time.strftime('%X %x') +" {% endcomment %}" ) # Add clock to force svn commit - fout.close() -except: pass - hakemisto=os.path.normpath(os.path.dirname(__file__)) tarkistus= os.getcwd() diff --git a/web/templates/tupa/base.html b/web/templates/tupa/base.html index 40ae2406..d657ff3d 100644 --- a/web/templates/tupa/base.html +++ b/web/templates/tupa/base.html @@ -69,7 +69,6 @@ {{kisa_nimi|alaviiva_pois}} {%if taakse.url and taakse.title%}» {{taakse.title|alaviiva_pois}} {% endif %}» {{heading|alaviiva_pois}} {% endif %} -
{% include "version.html" %}
diff --git a/web/templates/tupa/index.html b/web/templates/tupa/index.html index 07f74777..9ef78730 100644 --- a/web/templates/tupa/index.html +++ b/web/templates/tupa/index.html @@ -43,7 +43,7 @@

Kisat

- + diff --git a/web/templates/version.html b/web/templates/version.html deleted file mode 100644 index 4e4d33dc..00000000 --- a/web/templates/version.html +++ /dev/null @@ -1,2 +0,0 @@ -Kipa SVN {{"$Rev$"|cut:"$"}} -{% comment %} 00:29:24 11/09/15 {% endcomment %} \ No newline at end of file