aboutsummaryrefslogtreecommitdiff
path: root/api/social/create_relation.py
blob: 5367ac5c7c43e04bcb47e4a98a37f43c0d6503c2 (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
from flask import Blueprint, request
from db import cursor, connection
from hierarchy import auth_required, two_person
from socket_io import io
import time


def create_relation(user_1_id, user_2_id, relation_type):
	remove_relation(user_1_id, user_2_id)
	remove_relation(user_2_id, user_1_id)
	timestamp = int(time.time() * 1000)
	cursor.execute(
		"insert into social values (?, ?, ?, ?)",
		[user_1_id, user_2_id, relation_type, timestamp]
	)
	connection.commit()


# remove relation between user_1_id and user_2_id (one-way)
def remove_relation(user_1_id, user_2_id):
	cursor.execute(
		"delete from social where user_1_id = ? and user_2_id = ?",
		[user_1_id, user_2_id]
	)
	connection.commit()


def create_relation_route(relation_type):
	@two_person
	def route(user_1_id, user_2_id):
		create_relation(user_1_id, user_2_id, relation_type)

		if relation_type == "outgoing":
			io.emit("incomingFriendRequest", room="user-" + user_2_id)

		return "", 200

	return route


friend_request = Blueprint('friend_request', __name__)
friend_request.add_url_rule(
	'/request', 'route', create_relation_route("outgoing"), methods=["POST"]
)

block = Blueprint('block', __name__)
block.add_url_rule(
	'/block', 'route', create_relation_route("block"), methods=["POST"]
)

dynamic_routes = [["/social", friend_request], ["/social", block]]