Files
py-ailbl-user-phone/apps/ailbl-user_phone-insert-update-get.py

99 lines
3.2 KiB
Python
Raw Permalink Normal View History

2025-12-04 15:41:22 +07:00
import crud
from flask import jsonify, request
2025-12-09 14:10:13 +07:00
from filters import PhonePage
from helpers import CORS_HEADERS
from validators import validate_phone_number
2025-12-11 06:51:48 +00:00
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__)
2025-12-04 15:41:22 +07:00
2025-12-08 20:15:52 +07:00
2025-12-04 15:41:22 +07:00
def main():
"""
```fission
{
2025-12-10 09:57:16 +00:00
"name": "phonenumbers-users-get-insert",
2025-12-04 15:41:22 +07:00
"http_triggers": {
2025-12-10 09:57:16 +00:00
"phonenumbers-users-get-insert-http": {
2025-12-08 20:15:52 +07:00
"url": "/ailbl/users/phones",
2025-12-10 09:57:16 +00:00
"methods": ["POST", "GET"]
2025-12-04 15:41:22 +07:00
}
}
}
```
"""
try:
2025-12-10 09:57:16 +00:00
if request.method == "POST":
2025-12-04 15:41:22 +07:00
return make_insert_request()
elif request.method == "GET":
2025-12-08 20:15:52 +07:00
return make_get_request()
2025-12-04 15:41:22 +07:00
else:
return {"error": "Method not allow"}, 405
except Exception as ex:
return jsonify({"error": str(ex)}), 500
def make_insert_request():
try:
user_id = request.headers.get("X-User") # Lay user_id tu header X-User
2025-12-10 09:57:16 +00:00
2025-12-09 14:10:13 +07:00
if not user_id:
return jsonify({"error": "user_id or file is required"}), 400, CORS_HEADERS
2025-12-10 09:57:16 +00:00
2025-12-11 06:51:48 +00:00
data = request.get_json() # data = chua gia tri body gui len
2025-12-10 09:57:16 +00:00
if not data:
2025-12-09 14:10:13 +07:00
return jsonify({"error": "phone_number is required"}), 400, CORS_HEADERS
2025-12-10 09:57:16 +00:00
2025-12-11 06:51:48 +00:00
# Lay rieng field phone_number o trong body
2025-12-09 14:10:13 +07:00
phone_number = data.get("phone_number")
if not validate_phone_number(phone_number):
2025-12-11 06:51:48 +00:00
# Ghi log khi số điện thoại không hợp lệ
log.info(f"Invalid phone number: {phone_number}")
2025-12-09 14:10:13 +07:00
return jsonify({"error": "Invalid phone number"}), 400, CORS_HEADERS
2025-12-04 15:41:22 +07:00
2025-12-11 06:51:48 +00:00
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}")
2025-12-10 09:57:16 +00:00
return jsonify({"error": "Phone is exists"}), 404
2025-12-04 15:41:22 +07:00
2025-12-10 10:36:46 +00:00
response, status, headers = crud.create_phone(user_id, data)
2025-12-04 15:41:22 +07:00
2025-12-10 09:57:16 +00:00
return jsonify(response)
2025-12-04 15:41:22 +07:00
except Exception as e:
return jsonify({"error": str(e)}), 500
2025-12-08 20:15:52 +07:00
def make_get_request():
2025-12-04 15:41:22 +07:00
try:
user_id = request.headers.get("X-User")
if not user_id:
2025-12-09 14:10:13 +07:00
return jsonify({"error": "user_id is required"}), 400, CORS_HEADERS
2025-12-10 09:57:16 +00:00
2025-12-09 14:10:13 +07:00
# Lấy tham số filter và phân trang từ request
2025-12-10 09:57:16 +00:00
# Sử dụng default_factory để lấy filter và paging
paging = PhonePage.from_request_queries()
print(paging)
response = crud.filter_phone(user_id, paging)
2025-12-10 10:36:46 +00:00
# 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]
2025-12-11 06:51:48 +00:00
# return jsonify(response), 200, CORS_HEADERS
2025-12-04 15:41:22 +07:00
except Exception as e:
return jsonify({"error": str(e)}), 500