diff options
| -rw-r--r-- | api/auth/login.py | 2 | ||||
| -rw-r--r-- | api/auth/signup.py | 2 | ||||
| -rw-r--r-- | api/game/new.py | 25 | ||||
| -rw-r--r-- | api/main.py | 2 | ||||
| -rw-r--r-- | api/randid.py | 14 | ||||
| -rwxr-xr-x | api/tests.sh | 20 | ||||
| -rw-r--r-- | database/init_db.sql | 1 | 
7 files changed, 58 insertions, 8 deletions
| diff --git a/api/auth/login.py b/api/auth/login.py index 8eb0eea..e686b67 100644 --- a/api/auth/login.py +++ b/api/auth/login.py @@ -15,7 +15,7 @@ def index():      if not email or \         not password:             return "", 400 -     +      user_id = None      user_id = user_id or cursor.execute("select user_id from users where email = ?", [email]).fetchone()      user_id = user_id or cursor.execute("select user_id from users where username = ?", [email]).fetchone() diff --git a/api/auth/signup.py b/api/auth/signup.py index a9e155c..e77f82d 100644 --- a/api/auth/signup.py +++ b/api/auth/signup.py @@ -26,7 +26,7 @@ def index():      if cursor.execute("select email from users where email = ?", [email]).fetchone():          return {"error": "email_taken"}, 403 -    user_id = new_uuid() +    user_id = new_uuid("users")      password_hash = passwords.password_hash(password)      registered = int( time.time() * 1000 ) diff --git a/api/game/new.py b/api/game/new.py new file mode 100644 index 0000000..6f777e3 --- /dev/null +++ b/api/game/new.py @@ -0,0 +1,25 @@ +from flask import Blueprint, request, make_response +from main import cursor, connection +from randid import new_uuid +import time +import json + +new_game = Blueprint('new', __name__) + +@new_game.route('/new', methods = ['POST']) +def index(): +    data = request.get_json() + +    user_id = data.get("user_id") or "" # maybe set up a temporary user here? +    game_settings = data.get("settings") or "" + +    if not user_id: +        print("a temporary user should be set up here") + +    game_id = new_uuid("games") +    timestamp = int( time.time() * 1000 ) + +    cursor.execute("insert into games values (?, NULL, NULL, ?, NULL, NULL, ?, NULL, NULL, NULL, \"wait_for_opponent\", ?) ", (game_id, user_id, timestamp, json.dumps(game_settings))) +    connection.commit() + +    return { "id": game_id }, 200 diff --git a/api/main.py b/api/main.py index 0d16cbc..b9900f8 100644 --- a/api/main.py +++ b/api/main.py @@ -14,10 +14,12 @@ from user.info import info  from auth.signup import signup  from auth.login import login  from auth.login_token import token +from game.new import new_game  app.register_blueprint(status, url_prefix='/')  app.register_blueprint(info, url_prefix='/user')  app.register_blueprint(signup, url_prefix='/auth')  app.register_blueprint(login, url_prefix='/auth')  app.register_blueprint(token, url_prefix='/auth') +app.register_blueprint(new_game, url_prefix='/game') diff --git a/api/randid.py b/api/randid.py index b9292b6..645d0a0 100644 --- a/api/randid.py +++ b/api/randid.py @@ -1,11 +1,17 @@  from main import cursor  import uuid -def new_uuid(): +tables = { +        "users": "user_id", +        "games": "game_id" +        } + +def new_uuid(table_name):      temp_uuid = str(uuid.uuid4()) -    # check if user_id is already taken -    if cursor.execute("select user_id from users where user_id = ?", [temp_uuid]).fetchone(): -        return new_uuid() +    column_name = tables[table_name] +    # check if id is already taken +    if cursor.execute(f"select {column_name} from {table_name} where {column_name} = ?", [temp_uuid]).fetchone(): +        return new_uuid(table_name)      else:          return temp_uuid diff --git a/api/tests.sh b/api/tests.sh index 002f85f..3882699 100755 --- a/api/tests.sh +++ b/api/tests.sh @@ -54,5 +54,23 @@ user_info () {  # 		localhost:5000/api/auth/token  # } -user_info +new_game () { +	curl -X POST \ +		-H "Content-Type: application/json" \ +		-d '{ +			"user_id": "4577c119-c768-4ad5-afec-b53a5c19baf4", +			"settings": { +				"ranked": true, +				"timelimit": { +					"minutes": 5, +					"seconds": 30, +					"enabled": true, +					"shared": "false" +				} +			} +		}' \ +		localhost:5000/game/new +} + +new_game diff --git a/database/init_db.sql b/database/init_db.sql index 33a6c04..6e47853 100644 --- a/database/init_db.sql +++ b/database/init_db.sql @@ -27,7 +27,6 @@ create table if not exists games (  	duration integer,  	rating_delta_player_1 integer,  	rating_delta_player_2 integer, -	ranked boolean,  	status text not null,  	ruleset text not null,  	foreign key(player_1_id) references users(user_id), |