2026-04-29 19:56:27,846 - main - INFO - === Logging system initialized ===
2026-04-29 19:56:27,847 - main - INFO - Log file: logs/app_20260429_195627.log
2026-04-29 19:56:27,847 - main - INFO - Log level: INFO
2026-04-29 19:56:27,847 - main - INFO - Timestamp: 20260429_195627
2026-04-29 19:56:28,730 - main - INFO - Included router: routers.aihub.router
2026-04-29 19:56:28,750 - main - INFO - Included router: routers.auth.router
2026-04-29 19:56:28,772 - main - INFO - Included router: routers.contact.router
2026-04-29 19:56:28,775 - main - INFO - Included router: routers.health.router
2026-04-29 19:56:28,840 - main - INFO - Included router: routers.plans.router
2026-04-29 19:56:28,862 - main - INFO - Included router: routers.settings.router
2026-04-29 19:56:28,897 - main - INFO - Included router: routers.smtp_settings.router
2026-04-29 19:56:28,932 - main - INFO - Included router: routers.storage.router
2026-04-29 19:56:28,940 - main - INFO - Included router: routers.user.router
2026-04-29 19:56:28,982 - main - INFO - Included router: routers.user_profiles.router
2026-04-29 19:56:29,088 - main - INFO - Included router: routers.whmcs.router
2026-04-29 19:56:29,112 - main - INFO - Included router: routers.whmcs_admin.router
2026-04-29 19:56:29,166 - main - INFO - Included router: routers.whmcs_extra.router
2026-04-29 19:56:29,168 - main - INFO - === Application startup initiated ===
2026-04-29 19:56:29,168 - services.database - INFO - Ignore creating tables
2026-04-29 19:56:29,168 - services.mock_data - INFO - Ignore initialize data
2026-04-29 19:56:29,168 - services.auth - INFO - Ignore initialize admin
2026-04-29 19:56:29,168 - main - INFO - === Application startup completed successfully ===
2026-04-29 19:57:12,131 - httpcore.connection - DEBUG - connect_tcp.started host='client.doiteasy.net' port=443 local_address=None timeout=10.0 socket_options=None
2026-04-29 19:57:12,490 - httpcore.connection - DEBUG - connect_tcp.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0b60c10>
2026-04-29 19:57:12,491 - httpcore.connection - DEBUG - start_tls.started ssl_context=<ssl.SSLContext object at 0x7fb0b159b5c0> server_hostname='client.doiteasy.net' timeout=10.0
2026-04-29 19:57:12,672 - httpcore.connection - DEBUG - start_tls.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b16e3640>
2026-04-29 19:57:12,673 - httpcore.http11 - DEBUG - send_request_headers.started request=<Request [b'POST']>
2026-04-29 19:57:12,674 - httpcore.http11 - DEBUG - send_request_headers.complete
2026-04-29 19:57:12,674 - httpcore.http11 - DEBUG - send_request_body.started request=<Request [b'POST']>
2026-04-29 19:57:12,674 - httpcore.http11 - DEBUG - send_request_body.complete
2026-04-29 19:57:12,674 - httpcore.http11 - DEBUG - receive_response_headers.started request=<Request [b'POST']>
2026-04-29 19:57:12,999 - httpcore.http11 - DEBUG - receive_response_headers.complete return_value=(b'HTTP/1.1', 403, b'Forbidden', [(b'Server', b'nginx'), (b'Date', b'Thu, 30 Apr 2026 02:57:12 GMT'), (b'Content-Type', b'application/json'), (b'Transfer-Encoding', b'chunked'), (b'Connection', b'keep-alive'), (b'Expires', b'Thu, 19 Nov 1981 08:52:00 GMT'), (b'Cache-Control', b'no-store, no-cache, must-revalidate'), (b'Pragma', b'no-cache'), (b'Set-Cookie', b'WHMCShaXcqDDHD9SP=03efe79f67c1664cede680030053d8ea; path=/; secure; HttpOnly'), (b'X-Content-Type-Options', b'nosniff'), (b'X-Frame-Options', b'SAMEORIGIN'), (b'Referrer-Policy', b'strict-origin-when-cross-origin'), (b'X-XSS-Protection', b'1; mode=block')])
2026-04-29 19:57:13,001 - httpx - INFO - HTTP Request: POST https://client.doiteasy.net/includes/api.php "HTTP/1.1 403 Forbidden"
2026-04-29 19:57:13,002 - httpcore.http11 - DEBUG - receive_response_body.started request=<Request [b'POST']>
2026-04-29 19:57:13,002 - httpcore.http11 - DEBUG - receive_response_body.complete
2026-04-29 19:57:13,003 - httpcore.http11 - DEBUG - response_closed.started
2026-04-29 19:57:13,003 - httpcore.http11 - DEBUG - response_closed.complete
2026-04-29 19:57:13,003 - httpcore.connection - DEBUG - close.started
2026-04-29 19:57:13,004 - httpcore.connection - DEBUG - close.complete
2026-04-29 19:57:13,004 - services.whmcs - ERROR - WHMCS API returned HTTP 403 for action ValidateLogin: {"result":"error","message":"Invalid IP 154.197.56.221"}
2026-04-29 19:57:13,036 - core.database - WARNING - Database not initialized, attempting lazy initialization...
2026-04-29 19:57:13,036 - core.database - INFO - Starting database initialization...
2026-04-29 19:57:13,036 - core.config - DEBUG - Read dynamic attribute database_url from environment variable DATABASE_URL
2026-04-29 19:57:13,037 - core.database - INFO - Normalizing database URL for async compatibility...
2026-04-29 19:57:13,038 - core.database - INFO - Creating async database engine...
2026-04-29 19:57:13,038 - core.database - INFO - Using QueuePool with connection pooling for non-Lambda environment
2026-04-29 19:57:13,085 - core.database - INFO - Database engine created successfully
2026-04-29 19:57:13,085 - core.database - INFO - Creating async session maker...
2026-04-29 19:57:13,085 - core.database - INFO - Async session maker created successfully
2026-04-29 19:57:13,085 - core.database - INFO - Database connection initialized successfully
2026-04-29 19:57:13,085 - core.database - DEBUG - [DB_OP] Starting create_tables
2026-04-29 19:57:13,085 - core.database - INFO - 🔧 Starting table creation...
2026-04-29 19:57:14,648 - core.database - INFO - Tables initialized successfully
2026-04-29 19:57:14,648 - core.database - DEBUG - [DB_OP] Create tables completed in 1.5631s
2026-04-29 19:57:14,712 - core.database - INFO - Lazy database initialization completed successfully
2026-04-29 19:57:29,851 - httpcore.connection - DEBUG - connect_tcp.started host='client.doiteasy.net' port=443 local_address=None timeout=10.0 socket_options=None
2026-04-29 19:57:30,239 - httpcore.connection - DEBUG - connect_tcp.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0185780>
2026-04-29 19:57:30,239 - httpcore.connection - DEBUG - start_tls.started ssl_context=<ssl.SSLContext object at 0x7fb0b02b5d40> server_hostname='client.doiteasy.net' timeout=10.0
2026-04-29 19:57:30,414 - httpcore.connection - DEBUG - start_tls.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b02e7bb0>
2026-04-29 19:57:30,415 - httpcore.http11 - DEBUG - send_request_headers.started request=<Request [b'POST']>
2026-04-29 19:57:30,415 - httpcore.http11 - DEBUG - send_request_headers.complete
2026-04-29 19:57:30,416 - httpcore.http11 - DEBUG - send_request_body.started request=<Request [b'POST']>
2026-04-29 19:57:30,416 - httpcore.http11 - DEBUG - send_request_body.complete
2026-04-29 19:57:30,416 - httpcore.http11 - DEBUG - receive_response_headers.started request=<Request [b'POST']>
2026-04-29 19:57:30,724 - httpcore.http11 - DEBUG - receive_response_headers.complete return_value=(b'HTTP/1.1', 403, b'Forbidden', [(b'Server', b'nginx'), (b'Date', b'Thu, 30 Apr 2026 02:57:30 GMT'), (b'Content-Type', b'application/json'), (b'Transfer-Encoding', b'chunked'), (b'Connection', b'keep-alive'), (b'Expires', b'Thu, 19 Nov 1981 08:52:00 GMT'), (b'Cache-Control', b'no-store, no-cache, must-revalidate'), (b'Pragma', b'no-cache'), (b'Set-Cookie', b'WHMCShaXcqDDHD9SP=55fd4690164127b902de5f83418f63d5; path=/; secure; HttpOnly'), (b'X-Content-Type-Options', b'nosniff'), (b'X-Frame-Options', b'SAMEORIGIN'), (b'Referrer-Policy', b'strict-origin-when-cross-origin'), (b'X-XSS-Protection', b'1; mode=block')])
2026-04-29 19:57:30,725 - httpx - INFO - HTTP Request: POST https://client.doiteasy.net/includes/api.php "HTTP/1.1 403 Forbidden"
2026-04-29 19:57:30,725 - httpcore.http11 - DEBUG - receive_response_body.started request=<Request [b'POST']>
2026-04-29 19:57:30,725 - httpcore.http11 - DEBUG - receive_response_body.complete
2026-04-29 19:57:30,726 - httpcore.http11 - DEBUG - response_closed.started
2026-04-29 19:57:30,726 - httpcore.http11 - DEBUG - response_closed.complete
2026-04-29 19:57:30,726 - httpcore.connection - DEBUG - close.started
2026-04-29 19:57:30,727 - httpcore.connection - DEBUG - close.complete
2026-04-29 19:57:30,727 - services.whmcs - ERROR - WHMCS API returned HTTP 403 for action ValidateLogin: {"result":"error","message":"Invalid IP 154.197.56.221"}
2026-04-29 20:03:20,819 - httpcore.connection - DEBUG - connect_tcp.started host='client.doiteasy.net' port=443 local_address=None timeout=10.0 socket_options=None
2026-04-29 20:03:21,235 - httpcore.connection - DEBUG - connect_tcp.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0187430>
2026-04-29 20:03:21,235 - httpcore.connection - DEBUG - start_tls.started ssl_context=<ssl.SSLContext object at 0x7fb0b02b5fc0> server_hostname='client.doiteasy.net' timeout=10.0
2026-04-29 20:03:21,435 - httpcore.connection - DEBUG - start_tls.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b01871c0>
2026-04-29 20:03:21,436 - httpcore.http11 - DEBUG - send_request_headers.started request=<Request [b'POST']>
2026-04-29 20:03:21,436 - httpcore.http11 - DEBUG - send_request_headers.complete
2026-04-29 20:03:21,436 - httpcore.http11 - DEBUG - send_request_body.started request=<Request [b'POST']>
2026-04-29 20:03:21,437 - httpcore.http11 - DEBUG - send_request_body.complete
2026-04-29 20:03:21,437 - httpcore.http11 - DEBUG - receive_response_headers.started request=<Request [b'POST']>
2026-04-29 20:03:21,734 - httpcore.http11 - DEBUG - receive_response_headers.complete return_value=(b'HTTP/1.1', 403, b'Forbidden', [(b'Server', b'nginx'), (b'Date', b'Thu, 30 Apr 2026 03:03:21 GMT'), (b'Content-Type', b'application/json'), (b'Transfer-Encoding', b'chunked'), (b'Connection', b'keep-alive'), (b'Expires', b'Thu, 19 Nov 1981 08:52:00 GMT'), (b'Cache-Control', b'no-store, no-cache, must-revalidate'), (b'Pragma', b'no-cache'), (b'Set-Cookie', b'WHMCShaXcqDDHD9SP=b02edcc7e913f5fc19630c3713b36930; path=/; secure; HttpOnly'), (b'X-Content-Type-Options', b'nosniff'), (b'X-Frame-Options', b'SAMEORIGIN'), (b'Referrer-Policy', b'strict-origin-when-cross-origin'), (b'X-XSS-Protection', b'1; mode=block')])
2026-04-29 20:03:21,735 - httpx - INFO - HTTP Request: POST https://client.doiteasy.net/includes/api.php "HTTP/1.1 403 Forbidden"
2026-04-29 20:03:21,735 - httpcore.http11 - DEBUG - receive_response_body.started request=<Request [b'POST']>
2026-04-29 20:03:21,735 - httpcore.http11 - DEBUG - receive_response_body.complete
2026-04-29 20:03:21,736 - httpcore.http11 - DEBUG - response_closed.started
2026-04-29 20:03:21,736 - httpcore.http11 - DEBUG - response_closed.complete
2026-04-29 20:03:21,736 - httpcore.connection - DEBUG - close.started
2026-04-29 20:03:21,736 - httpcore.connection - DEBUG - close.complete
2026-04-29 20:03:21,737 - services.whmcs - ERROR - WHMCS API returned HTTP 403 for action ValidateLogin: {"result":"error","message":"Invalid IP 154.197.56.221"}
2026-04-29 20:03:49,831 - httpcore.connection - DEBUG - connect_tcp.started host='client.doiteasy.net' port=443 local_address=None timeout=10.0 socket_options=None
2026-04-29 20:03:50,233 - httpcore.connection - DEBUG - connect_tcp.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0198a60>
2026-04-29 20:03:50,233 - httpcore.connection - DEBUG - start_tls.started ssl_context=<ssl.SSLContext object at 0x7fb0b02b62c0> server_hostname='client.doiteasy.net' timeout=10.0
2026-04-29 20:03:50,414 - httpcore.connection - DEBUG - start_tls.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0184ca0>
2026-04-29 20:03:50,415 - httpcore.http11 - DEBUG - send_request_headers.started request=<Request [b'POST']>
2026-04-29 20:03:50,415 - httpcore.http11 - DEBUG - send_request_headers.complete
2026-04-29 20:03:50,415 - httpcore.http11 - DEBUG - send_request_body.started request=<Request [b'POST']>
2026-04-29 20:03:50,416 - httpcore.http11 - DEBUG - send_request_body.complete
2026-04-29 20:03:50,416 - httpcore.http11 - DEBUG - receive_response_headers.started request=<Request [b'POST']>
2026-04-29 20:03:50,729 - httpcore.http11 - DEBUG - receive_response_headers.complete return_value=(b'HTTP/1.1', 403, b'Forbidden', [(b'Server', b'nginx'), (b'Date', b'Thu, 30 Apr 2026 03:03:50 GMT'), (b'Content-Type', b'application/json'), (b'Transfer-Encoding', b'chunked'), (b'Connection', b'keep-alive'), (b'Expires', b'Thu, 19 Nov 1981 08:52:00 GMT'), (b'Cache-Control', b'no-store, no-cache, must-revalidate'), (b'Pragma', b'no-cache'), (b'Set-Cookie', b'WHMCShaXcqDDHD9SP=5037eef9c43f4ef5b3e762c4fd5e3e77; path=/; secure; HttpOnly'), (b'X-Content-Type-Options', b'nosniff'), (b'X-Frame-Options', b'SAMEORIGIN'), (b'Referrer-Policy', b'strict-origin-when-cross-origin'), (b'X-XSS-Protection', b'1; mode=block')])
2026-04-29 20:03:50,730 - httpx - INFO - HTTP Request: POST https://client.doiteasy.net/includes/api.php "HTTP/1.1 403 Forbidden"
2026-04-29 20:03:50,730 - httpcore.http11 - DEBUG - receive_response_body.started request=<Request [b'POST']>
2026-04-29 20:03:50,730 - httpcore.http11 - DEBUG - receive_response_body.complete
2026-04-29 20:03:50,731 - httpcore.http11 - DEBUG - response_closed.started
2026-04-29 20:03:50,731 - httpcore.http11 - DEBUG - response_closed.complete
2026-04-29 20:03:50,731 - httpcore.connection - DEBUG - close.started
2026-04-29 20:03:50,731 - httpcore.connection - DEBUG - close.complete
2026-04-29 20:03:50,732 - services.whmcs - ERROR - WHMCS API returned HTTP 403 for action ValidateLogin: {"result":"error","message":"Invalid IP 154.197.56.221"}
2026-04-29 20:04:20,274 - httpcore.connection - DEBUG - connect_tcp.started host='client.doiteasy.net' port=443 local_address=None timeout=10.0 socket_options=None
2026-04-29 20:04:20,610 - httpcore.connection - DEBUG - connect_tcp.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b1528b80>
2026-04-29 20:04:20,610 - httpcore.connection - DEBUG - start_tls.started ssl_context=<ssl.SSLContext object at 0x7fb0b02b6340> server_hostname='client.doiteasy.net' timeout=10.0
2026-04-29 20:04:20,786 - httpcore.connection - DEBUG - start_tls.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b15282b0>
2026-04-29 20:04:20,787 - httpcore.http11 - DEBUG - send_request_headers.started request=<Request [b'POST']>
2026-04-29 20:04:20,787 - httpcore.http11 - DEBUG - send_request_headers.complete
2026-04-29 20:04:20,788 - httpcore.http11 - DEBUG - send_request_body.started request=<Request [b'POST']>
2026-04-29 20:04:20,788 - httpcore.http11 - DEBUG - send_request_body.complete
2026-04-29 20:04:20,788 - httpcore.http11 - DEBUG - receive_response_headers.started request=<Request [b'POST']>
2026-04-29 20:04:21,145 - httpcore.http11 - DEBUG - receive_response_headers.complete return_value=(b'HTTP/1.1', 403, b'Forbidden', [(b'Server', b'nginx'), (b'Date', b'Thu, 30 Apr 2026 03:04:21 GMT'), (b'Content-Type', b'application/json'), (b'Transfer-Encoding', b'chunked'), (b'Connection', b'keep-alive'), (b'Expires', b'Thu, 19 Nov 1981 08:52:00 GMT'), (b'Cache-Control', b'no-store, no-cache, must-revalidate'), (b'Pragma', b'no-cache'), (b'Set-Cookie', b'WHMCShaXcqDDHD9SP=1f6c302210e5e1b40f8ec6a440b1a382; path=/; secure; HttpOnly'), (b'X-Content-Type-Options', b'nosniff'), (b'X-Frame-Options', b'SAMEORIGIN'), (b'Referrer-Policy', b'strict-origin-when-cross-origin'), (b'X-XSS-Protection', b'1; mode=block')])
2026-04-29 20:04:21,146 - httpx - INFO - HTTP Request: POST https://client.doiteasy.net/includes/api.php "HTTP/1.1 403 Forbidden"
2026-04-29 20:04:21,147 - httpcore.http11 - DEBUG - receive_response_body.started request=<Request [b'POST']>
2026-04-29 20:04:21,147 - httpcore.http11 - DEBUG - receive_response_body.complete
2026-04-29 20:04:21,147 - httpcore.http11 - DEBUG - response_closed.started
2026-04-29 20:04:21,148 - httpcore.http11 - DEBUG - response_closed.complete
2026-04-29 20:04:21,148 - httpcore.connection - DEBUG - close.started
2026-04-29 20:04:21,149 - httpcore.connection - DEBUG - close.complete
2026-04-29 20:04:21,149 - services.whmcs - ERROR - WHMCS API returned HTTP 403 for action ValidateLogin: {"result":"error","message":"Invalid IP 154.197.56.221"}
2026-04-29 20:06:28,720 - httpcore.connection - DEBUG - connect_tcp.started host='client.doiteasy.net' port=443 local_address=None timeout=10.0 socket_options=None
2026-04-29 20:06:29,084 - httpcore.connection - DEBUG - connect_tcp.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0186a10>
2026-04-29 20:06:29,084 - httpcore.connection - DEBUG - start_tls.started ssl_context=<ssl.SSLContext object at 0x7fb0b0b15940> server_hostname='client.doiteasy.net' timeout=10.0
2026-04-29 20:06:29,259 - httpcore.connection - DEBUG - start_tls.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0187160>
2026-04-29 20:06:29,260 - httpcore.http11 - DEBUG - send_request_headers.started request=<Request [b'POST']>
2026-04-29 20:06:29,260 - httpcore.http11 - DEBUG - send_request_headers.complete
2026-04-29 20:06:29,260 - httpcore.http11 - DEBUG - send_request_body.started request=<Request [b'POST']>
2026-04-29 20:06:29,261 - httpcore.http11 - DEBUG - send_request_body.complete
2026-04-29 20:06:29,261 - httpcore.http11 - DEBUG - receive_response_headers.started request=<Request [b'POST']>
2026-04-29 20:06:29,658 - httpcore.http11 - DEBUG - receive_response_headers.complete return_value=(b'HTTP/1.1', 200, b'OK', [(b'Server', b'nginx'), (b'Date', b'Thu, 30 Apr 2026 03:06:29 GMT'), (b'Content-Type', b'application/json'), (b'Transfer-Encoding', b'chunked'), (b'Connection', b'keep-alive'), (b'Expires', b'Thu, 19 Nov 1981 08:52:00 GMT'), (b'Cache-Control', b'no-store, no-cache, must-revalidate'), (b'Pragma', b'no-cache'), (b'Set-Cookie', b'WHMCShaXcqDDHD9SP=1c18dd18dcfbcc977c3c7e5d95464f10; path=/; secure; HttpOnly'), (b'X-Content-Type-Options', b'nosniff'), (b'X-Frame-Options', b'SAMEORIGIN'), (b'Referrer-Policy', b'strict-origin-when-cross-origin'), (b'X-XSS-Protection', b'1; mode=block')])
2026-04-29 20:06:29,659 - httpx - INFO - HTTP Request: POST https://client.doiteasy.net/includes/api.php "HTTP/1.1 200 OK"
2026-04-29 20:06:29,660 - httpcore.http11 - DEBUG - receive_response_body.started request=<Request [b'POST']>
2026-04-29 20:06:29,660 - httpcore.http11 - DEBUG - receive_response_body.complete
2026-04-29 20:06:29,660 - httpcore.http11 - DEBUG - response_closed.started
2026-04-29 20:06:29,660 - httpcore.http11 - DEBUG - response_closed.complete
2026-04-29 20:06:29,661 - httpcore.connection - DEBUG - close.started
2026-04-29 20:06:29,661 - httpcore.connection - DEBUG - close.complete
2026-04-29 20:06:29,661 - services.whmcs - WARNING - WHMCS API error for action ValidateLogin: Email or Password Invalid
2026-04-29 20:06:36,296 - httpcore.connection - DEBUG - connect_tcp.started host='client.doiteasy.net' port=443 local_address=None timeout=10.0 socket_options=None
2026-04-29 20:06:36,474 - httpcore.connection - DEBUG - connect_tcp.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0185930>
2026-04-29 20:06:36,474 - httpcore.connection - DEBUG - start_tls.started ssl_context=<ssl.SSLContext object at 0x7fb0b02b65c0> server_hostname='client.doiteasy.net' timeout=10.0
2026-04-29 20:06:36,656 - httpcore.connection - DEBUG - start_tls.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0185630>
2026-04-29 20:06:36,657 - httpcore.http11 - DEBUG - send_request_headers.started request=<Request [b'POST']>
2026-04-29 20:06:36,657 - httpcore.http11 - DEBUG - send_request_headers.complete
2026-04-29 20:06:36,658 - httpcore.http11 - DEBUG - send_request_body.started request=<Request [b'POST']>
2026-04-29 20:06:36,658 - httpcore.http11 - DEBUG - send_request_body.complete
2026-04-29 20:06:36,658 - httpcore.http11 - DEBUG - receive_response_headers.started request=<Request [b'POST']>
2026-04-29 20:06:37,038 - httpcore.http11 - DEBUG - receive_response_headers.complete return_value=(b'HTTP/1.1', 200, b'OK', [(b'Server', b'nginx'), (b'Date', b'Thu, 30 Apr 2026 03:06:36 GMT'), (b'Content-Type', b'application/json'), (b'Transfer-Encoding', b'chunked'), (b'Connection', b'keep-alive'), (b'Expires', b'Thu, 19 Nov 1981 08:52:00 GMT'), (b'Cache-Control', b'no-store, no-cache, must-revalidate'), (b'Pragma', b'no-cache'), (b'Set-Cookie', b'WHMCShaXcqDDHD9SP=d10fc2c6dfccb31ae4c76113b0640f5e; path=/; secure; HttpOnly'), (b'X-Content-Type-Options', b'nosniff'), (b'X-Frame-Options', b'SAMEORIGIN'), (b'Referrer-Policy', b'strict-origin-when-cross-origin'), (b'X-XSS-Protection', b'1; mode=block')])
2026-04-29 20:06:37,039 - httpx - INFO - HTTP Request: POST https://client.doiteasy.net/includes/api.php "HTTP/1.1 200 OK"
2026-04-29 20:06:37,039 - httpcore.http11 - DEBUG - receive_response_body.started request=<Request [b'POST']>
2026-04-29 20:06:37,040 - httpcore.http11 - DEBUG - receive_response_body.complete
2026-04-29 20:06:37,040 - httpcore.http11 - DEBUG - response_closed.started
2026-04-29 20:06:37,040 - httpcore.http11 - DEBUG - response_closed.complete
2026-04-29 20:06:37,041 - httpcore.connection - DEBUG - close.started
2026-04-29 20:06:37,042 - httpcore.connection - DEBUG - close.complete
2026-04-29 20:06:37,043 - services.whmcs - WARNING - WHMCS API error for action ValidateLogin: Email or Password Invalid
2026-04-29 20:07:47,194 - httpcore.connection - DEBUG - connect_tcp.started host='client.doiteasy.net' port=443 local_address=None timeout=10.0 socket_options=None
2026-04-29 20:07:47,547 - httpcore.connection - DEBUG - connect_tcp.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0198940>
2026-04-29 20:07:47,548 - httpcore.connection - DEBUG - start_tls.started ssl_context=<ssl.SSLContext object at 0x7fb0b02b66c0> server_hostname='client.doiteasy.net' timeout=10.0
2026-04-29 20:07:47,732 - httpcore.connection - DEBUG - start_tls.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0185c00>
2026-04-29 20:07:47,732 - httpcore.http11 - DEBUG - send_request_headers.started request=<Request [b'POST']>
2026-04-29 20:07:47,733 - httpcore.http11 - DEBUG - send_request_headers.complete
2026-04-29 20:07:47,733 - httpcore.http11 - DEBUG - send_request_body.started request=<Request [b'POST']>
2026-04-29 20:07:47,733 - httpcore.http11 - DEBUG - send_request_body.complete
2026-04-29 20:07:47,734 - httpcore.http11 - DEBUG - receive_response_headers.started request=<Request [b'POST']>
2026-04-29 20:07:48,166 - httpcore.http11 - DEBUG - receive_response_headers.complete return_value=(b'HTTP/1.1', 200, b'OK', [(b'Server', b'nginx'), (b'Date', b'Thu, 30 Apr 2026 03:07:48 GMT'), (b'Content-Type', b'application/json'), (b'Transfer-Encoding', b'chunked'), (b'Connection', b'keep-alive'), (b'Expires', b'Thu, 19 Nov 1981 08:52:00 GMT'), (b'Cache-Control', b'no-store, no-cache, must-revalidate'), (b'Pragma', b'no-cache'), (b'Set-Cookie', b'WHMCShaXcqDDHD9SP=0c2c6f396ad24ed9353df4a77a83b81c; path=/; secure; HttpOnly'), (b'X-Content-Type-Options', b'nosniff'), (b'X-Frame-Options', b'SAMEORIGIN'), (b'Referrer-Policy', b'strict-origin-when-cross-origin'), (b'X-XSS-Protection', b'1; mode=block')])
2026-04-29 20:07:48,167 - httpx - INFO - HTTP Request: POST https://client.doiteasy.net/includes/api.php "HTTP/1.1 200 OK"
2026-04-29 20:07:48,168 - httpcore.http11 - DEBUG - receive_response_body.started request=<Request [b'POST']>
2026-04-29 20:07:48,168 - httpcore.http11 - DEBUG - receive_response_body.complete
2026-04-29 20:07:48,168 - httpcore.http11 - DEBUG - response_closed.started
2026-04-29 20:07:48,169 - httpcore.http11 - DEBUG - response_closed.complete
2026-04-29 20:07:48,169 - httpcore.connection - DEBUG - close.started
2026-04-29 20:07:48,169 - httpcore.connection - DEBUG - close.complete
2026-04-29 20:07:48,216 - httpcore.connection - DEBUG - connect_tcp.started host='client.doiteasy.net' port=443 local_address=None timeout=10.0 socket_options=None
2026-04-29 20:07:48,569 - httpcore.connection - DEBUG - connect_tcp.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b1528be0>
2026-04-29 20:07:48,590 - httpcore.connection - DEBUG - start_tls.started ssl_context=<ssl.SSLContext object at 0x7fb0b02b5040> server_hostname='client.doiteasy.net' timeout=10.0
2026-04-29 20:07:48,768 - httpcore.connection - DEBUG - start_tls.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b1528b80>
2026-04-29 20:07:48,769 - httpcore.http11 - DEBUG - send_request_headers.started request=<Request [b'POST']>
2026-04-29 20:07:48,770 - httpcore.http11 - DEBUG - send_request_headers.complete
2026-04-29 20:07:48,770 - httpcore.http11 - DEBUG - send_request_body.started request=<Request [b'POST']>
2026-04-29 20:07:48,771 - httpcore.http11 - DEBUG - send_request_body.complete
2026-04-29 20:07:48,771 - httpcore.http11 - DEBUG - receive_response_headers.started request=<Request [b'POST']>
2026-04-29 20:07:49,157 - httpcore.http11 - DEBUG - receive_response_headers.complete return_value=(b'HTTP/1.1', 200, b'OK', [(b'Server', b'nginx'), (b'Date', b'Thu, 30 Apr 2026 03:07:49 GMT'), (b'Content-Type', b'application/json'), (b'Transfer-Encoding', b'chunked'), (b'Connection', b'keep-alive'), (b'Expires', b'Thu, 19 Nov 1981 08:52:00 GMT'), (b'Cache-Control', b'no-store, no-cache, must-revalidate'), (b'Pragma', b'no-cache'), (b'Set-Cookie', b'WHMCShaXcqDDHD9SP=9e7915a5884dfa194030ad970029a228; path=/; secure; HttpOnly'), (b'X-Content-Type-Options', b'nosniff'), (b'X-Frame-Options', b'SAMEORIGIN'), (b'Referrer-Policy', b'strict-origin-when-cross-origin'), (b'X-XSS-Protection', b'1; mode=block')])
2026-04-29 20:07:49,158 - httpx - INFO - HTTP Request: POST https://client.doiteasy.net/includes/api.php "HTTP/1.1 200 OK"
2026-04-29 20:07:49,159 - httpcore.http11 - DEBUG - receive_response_body.started request=<Request [b'POST']>
2026-04-29 20:07:49,159 - httpcore.http11 - DEBUG - receive_response_body.complete
2026-04-29 20:07:49,160 - httpcore.http11 - DEBUG - response_closed.started
2026-04-29 20:07:49,160 - httpcore.http11 - DEBUG - response_closed.complete
2026-04-29 20:07:49,160 - httpcore.connection - DEBUG - close.started
2026-04-29 20:07:49,160 - httpcore.connection - DEBUG - close.complete
2026-04-29 20:07:49,161 - core.config - DEBUG - Read dynamic attribute jwt_secret_key from environment variable JWT_SECRET_KEY
2026-04-29 20:07:49,161 - core.config - DEBUG - Read dynamic attribute jwt_expire_minutes from environment variable JWT_EXPIRE_MINUTES
2026-04-29 20:07:49,161 - core.config - DEBUG - Read dynamic attribute jwt_algorithm from environment variable JWT_ALGORITHM
2026-04-29 20:07:49,425 - core.auth - DEBUG - Authentication token created for user hash: 8c5e6440
2026-04-29 20:07:49,690 - core.auth - DEBUG - Authentication token validated for user hash: 8c5e6440
2026-04-29 20:07:49,694 - dependencies.auth - DEBUG - Authentication required for request GET /api/v1/whmcs/me
2026-04-29 20:07:49,939 - dependencies.auth - DEBUG - Authentication required for request GET /api/v1/storage/list-objects
2026-04-29 20:07:55,901 - dependencies.auth - DEBUG - Authentication required for request GET /api/v1/whmcs/me
2026-04-29 20:07:56,921 - dependencies.auth - DEBUG - Authentication required for request GET /api/v1/whmcs/me
2026-04-29 20:07:58,896 - dependencies.auth - DEBUG - Authentication required for request GET /api/v1/whmcs/me
2026-04-29 20:08:23,195 - core.auth - DEBUG - Authentication token validated for user hash: 8c5e6440
2026-04-29 20:08:23,443 - core.auth - DEBUG - Authentication token validated for user hash: 8c5e6440
2026-04-29 20:08:23,443 - core.config - DEBUG - Read dynamic attribute oss_service_url from environment variable OSS_SERVICE_URL
2026-04-29 20:08:23,444 - core.config - DEBUG - Read dynamic attribute oss_api_key from environment variable OSS_API_KEY
2026-04-29 20:08:23,484 - httpcore.connection - DEBUG - connect_tcp.started host='atoms.dev' port=443 local_address=None timeout=120.0 socket_options=None
2026-04-29 20:08:23,493 - httpcore.connection - DEBUG - connect_tcp.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0187e20>
2026-04-29 20:08:23,493 - httpcore.connection - DEBUG - start_tls.started ssl_context=<ssl.SSLContext object at 0x7fb0b01d5240> server_hostname='atoms.dev' timeout=120.0
2026-04-29 20:08:23,502 - httpcore.connection - DEBUG - start_tls.complete return_value=<httpcore._backends.anyio.AnyIOStream object at 0x7fb0b0185ab0>
2026-04-29 20:08:23,503 - httpcore.http11 - DEBUG - send_request_headers.started request=<Request [b'GET']>
2026-04-29 20:08:23,503 - httpcore.http11 - DEBUG - send_request_headers.complete
2026-04-29 20:08:23,504 - httpcore.http11 - DEBUG - send_request_body.started request=<Request [b'GET']>
2026-04-29 20:08:23,504 - httpcore.http11 - DEBUG - send_request_body.complete
2026-04-29 20:08:23,504 - httpcore.http11 - DEBUG - receive_response_headers.started request=<Request [b'GET']>
2026-04-29 20:08:23,758 - httpcore.http11 - DEBUG - receive_response_headers.complete return_value=(b'HTTP/1.1', 200, b'OK', [(b'Date', b'Thu, 30 Apr 2026 03:08:23 GMT'), (b'Content-Type', b'application/json; charset=utf-8'), (b'Transfer-Encoding', b'chunked'), (b'Connection', b'keep-alive'), (b'Access-Control-Allow-Headers', b'Origin, Content-Type, Accept, Authorization'), (b'Access-Control-Allow-Methods', b'GET, POST, PUT, DELETE, OPTIONS'), (b'Access-Control-Allow-Origin', b'*'), (b'Access-Control-Max-Age', b'86400'), (b'X-Request-Id', b'c540c8d53ae399ae380447896a77047f'), (b'X-Trace-Id', b'ea2464e7e05742c8881943307a04265e'), (b'Content-Security-Policy', b"frame-ancestors 'self' https://atoms.dev"), (b'Strict-Transport-Security', b'max-age=63072000; includeSubDomains; preload'), (b'X-Content-Type-Options', b'nosniff'), (b'X-XSS-Protection', b'1; mode=block'), (b'Referrer-Policy', b'strict-origin-when-cross-origin'), (b'cf-cache-status', b'DYNAMIC'), (b'Content-Encoding', b'gzip'), (b'Server', b'cloudflare'), (b'CF-RAY', b'9f435776ef63964b-LAX')])
2026-04-29 20:08:23,758 - httpx - INFO - HTTP Request: GET https://atoms.dev/api/v1/infra/client/oss/buckets/user-avatars/objects "HTTP/1.1 200 OK"
2026-04-29 20:08:23,759 - httpcore.http11 - DEBUG - receive_response_body.started request=<Request [b'GET']>
2026-04-29 20:08:23,759 - httpcore.http11 - DEBUG - receive_response_body.complete
2026-04-29 20:08:23,759 - httpcore.http11 - DEBUG - response_closed.started
2026-04-29 20:08:23,760 - httpcore.http11 - DEBUG - response_closed.complete
2026-04-29 20:08:23,760 - httpcore.connection - DEBUG - close.started
2026-04-29 20:08:23,760 - httpcore.connection - DEBUG - close.complete
2026-04-29 20:10:42,430 - services.database - DEBUG - [DB_OP] Starting database close
2026-04-29 20:10:42,498 - core.database - INFO - Database connection closed and engine disposed
2026-04-29 20:10:42,499 - services.database - INFO - Database connections closed
2026-04-29 20:10:42,499 - services.database - DEBUG - [DB_OP] Database close completed in 0.0688s
