PhoneDone
Some checks failed
K8S Fission Deployment / Deployment fission functions (push) Failing after 20s

This commit is contained in:
QuangMinh_123
2025-12-11 06:51:48 +00:00
parent ec3b3303f6
commit 69057654d5
5 changed files with 145 additions and 26 deletions

View File

@@ -1,5 +1,17 @@
import crud
from flask import jsonify, request
from filters import PhonePage
from helpers import CORS_HEADERS
import logging
# Cấu hình logging ở đây
logging.basicConfig(
level=logging.INFO, # Mức độ log
# Định dạng log
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
)
log = logging.getLogger(__name__)
def main():
@@ -27,11 +39,20 @@ def main():
def make_delete_request():
try:
user_id = request.headers.get("X-User")
# Lay user_id tu header X-User
user_id = request.headers.get("X-Fission-Params-UserId")
if not user_id:
return jsonify({"error": "user_id is required"}), 400
return jsonify({"error": "user_id is required"}), 400, CORS_HEADERS
response, status = crud
return jsonify(response), status
phone_id = request.headers.get("X-Fission-Params-UserPhoneId")
if not phone_id:
return jsonify({"error": "phone_id is required"}), 400, CORS_HEADERS
# Kiem tra so dien thoai co ton tai trong db khong ?
if not crud.exists_phone_for_delete(phone_id, user_id):
return jsonify({"error": "Phone not found"}), 404
response, status, headers = crud.delete_phone(phone_id, user_id)
return jsonify(response), status, CORS_HEADERS
except Exception as e:
return jsonify({"error": str(e)}), 500

View File

@@ -1,5 +1,18 @@
import crud
from flask import jsonify, request
from filters import PhonePage
from helpers import CORS_HEADERS
from validators import validate_phone_number
import logging
# # Cấu hình logging ở đây
# logging.basicConfig(
# level=logging.INFO, # Mức độ log
# # Định dạng log
# format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
# )
# log = logging.getLogger(__name__)
def main():
@@ -29,20 +42,54 @@ def main():
def make_insert_request():
try:
user_id = request.headers.get("X-User")
# Lay user_id tu header X-User
user_id = request.headers.get("X-Fission-Params-UserId")
response, status = crud
return jsonify(response), status
if not user_id:
return jsonify({"error": "user_id or file is required"}), 400, CORS_HEADERS
data = request.get_json() # data = chua gia tri body gui len
if not data:
return jsonify({"error": "phone_number is required"}), 400, CORS_HEADERS
# Lay rieng field phone_number o trong body
phone_number = data.get("phone_number")
if not validate_phone_number(phone_number):
return jsonify({"error": "Invalid phone number"}), 400, CORS_HEADERS
if crud.exists_phone_for_post(phone_number):
return jsonify({"error": "Phone is exists"}), 404
response, status, headers = crud.create_phone(user_id, data)
return jsonify(response)
except Exception as e:
return jsonify({"error": str(e)}), 500
def make_get_request():
try:
user_id = request.headers.get("X-User")
user_id = request.headers.get("X-Fission-Params-UserId")
if not user_id:
return jsonify({"error": "user_id is required"}), 400
return jsonify({"error": "user_id is required"}), 400, CORS_HEADERS
return crud
# Lấy tham số filter và phân trang từ request
# Sử dụng default_factory để lấy filter và paging
paging = PhonePage.from_request_queries()
print(paging)
response = crud.filter_phone(user_id, paging)
# Kiểm tra xem response có dữ liệu hay không
if not response[0]: # Nếu không có dữ liệu
return jsonify({"message": "No phone numbers found"}), 404, CORS_HEADERS
return jsonify({
"data": response[0], # Dữ liệu (danh sách các số điện thoại)
"status": response[1], # Mã trạng thái HTTP (200)
"headers": response[2] # Headers CORS
}), response[1], response[2]
# return jsonify(response), 200, CORS_HEADERS
except Exception as e:
return jsonify({"error": str(e)}), 500

View File

@@ -3,6 +3,16 @@ from flask import jsonify, request
from filters import PhonePage
from helpers import CORS_HEADERS
from validators import validate_phone_number
import logging
# Cấu hình logging ở đây
logging.basicConfig(
level=logging.INFO, # Mức độ log
# Định dạng log
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
)
log = logging.getLogger(__name__)
def main():
@@ -37,15 +47,20 @@ def make_insert_request():
if not user_id:
return jsonify({"error": "user_id or file is required"}), 400, CORS_HEADERS
data = request.get_json()
data = request.get_json() # data = chua gia tri body gui len
if not data:
return jsonify({"error": "phone_number is required"}), 400, CORS_HEADERS
# Lay rieng field phone_number o trong body
phone_number = data.get("phone_number")
if not validate_phone_number(phone_number):
# Ghi log khi số điện thoại không hợp lệ
log.info(f"Invalid phone number: {phone_number}")
return jsonify({"error": "Invalid phone number"}), 400, CORS_HEADERS
if crud.exists_phone(phone_number, user_id):
if crud.exists_phone_for_post(phone_number):
# Ghi log khi số điện thoại đã tồn tại
log.info(f"Phone number already exists: {phone_number}")
return jsonify({"error": "Phone is exists"}), 404
response, status, headers = crud.create_phone(user_id, data)
@@ -78,6 +93,6 @@ def make_get_request():
"headers": response[2] # Headers CORS
}), response[1], response[2]
return jsonify(response), 200, CORS_HEADERS
# return jsonify(response), 200, CORS_HEADERS
except Exception as e:
return jsonify({"error": str(e)}), 500

View File

@@ -2,6 +2,16 @@ import crud
from flask import jsonify, request
from filters import PhonePage
from helpers import CORS_HEADERS
import logging
# Cấu hình logging ở đây
logging.basicConfig(
level=logging.INFO, # Mức độ log
# Định dạng log
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
)
log = logging.getLogger(__name__)
def main():
@@ -31,17 +41,21 @@ def make_delete_request():
try:
user_id = request.headers.get("X-User") # Lay user_id tu header X-User
if not user_id:
return jsonify({"error": "user_id is required"}), 400
return jsonify({"error": "user_id is required"}), 400, CORS_HEADERS
phone_id = request.headers.get("X-Fission-Params-UserPhoneId")
if not phone_id:
return jsonify({"error": "phone_id is required"}), 400
return jsonify({"error": "phone_id is required"}), 400, CORS_HEADERS
log.info(f"DELETE request: user_id={user_id}, phone_id={phone_id}")
# Kiem tra so dien thoai co ton tai trong db khong ?
if not crud.exists_phone(phone_id, user_id):
if not crud.exists_phone_for_delete(phone_id, user_id):
log.info(
f"Phone not found: phone_id={phone_id}, user_id={user_id}")
return jsonify({"error": "Phone not found"}), 404
response, status = crud.delete_phone(phone_id, user_id)
return jsonify(response), status
response, status, headers = crud.delete_phone(phone_id, user_id)
return jsonify(response), status, CORS_HEADERS
except Exception as e:
return jsonify({"error": str(e)}), 500

View File

@@ -3,6 +3,7 @@ from filters import PhonePage
from flask import jsonify, request
from helpers import init_db_connection, CORS_HEADERS
from PIL import Image
import logging
def create_phone(user_id: str, data):
@@ -146,19 +147,38 @@ def delete_phone(phone_id: str, user_id: str) -> dict:
conn.close() # Đảm bảo đóng kết nối sau khi xong
def exists_phone(user_id: str, phone_number: str = None, phone_id: str = None):
# Nếu là `POST`, kiểm tra sự tồn tại của phone_number => Nghia la kiem tra so
def exists_phone_for_post(phone_number: str):
try:
conn = init_db_connection()
cursor = conn.cursor()
if phone_number: # Nếu là `POST`, kiểm tra sự tồn tại của phone_number => Nghia la kiem tra so
cursor.execute("""
SELECT 1
FROM ailbl_user_phone
WHERE user_id = %s AND phone_number = %s
""", (user_id, phone_number))
WHERE phone_number = %s
""", (phone_number,))
row = cursor.fetchone() # Co ket qua thi tra ve du lieu 1 dong
# Nếu có dòng dữ liệu, trả về True (tồn tại số điện thoại), nếu không, trả về False
return row is not None
except Exception as e:
# return True
logging.error(f"Database error checking phone existence: {e}")
raise
finally:
if cursor:
cursor.close()
if conn:
conn.close() # Đảm bảo đóng kết nối sau khi xong
# Nếu là `DELETE`, kiểm tra sự tồn tại của phone_id => Nghia la kiem tra id cua so phone do
def exists_phone_for_delete(phone_id: str, user_id: str):
try:
conn = init_db_connection()
cursor = conn.cursor()
elif phone_id: # Nếu là `DELETE`, kiểm tra sự tồn tại của phone_id => Nghia la kiem tra id cua so phone do
cursor.execute("""
SELECT 1
FROM ailbl_user_phone
@@ -169,7 +189,9 @@ def exists_phone(user_id: str, phone_number: str = None, phone_id: str = None):
# Nếu có dòng dữ liệu, trả về True (tồn tại số điện thoại), nếu không, trả về False
return row is not None
except Exception as e:
return False
# return False
logging.log.error(f"Database error in exists_phone_for_delete: {e}")
raise
finally:
if cursor:
cursor.close()