[
    {
        "file_name": "logger.py",
        "file_content": "import logging\nfrom datetime import datetime\n\n# Configure the logging system\nlogging.basicConfig(filename='activity_log.txt', level=logging.INFO,\n                    format='%(asctime)s - %(levelname)s - %(message)s')\n\ndef log_activity(user_id, action):\n    \"\"\"\n    Logs a user activity with a timestamp.\n\n    :param user_id: The ID of the user performing the action.\n    :param action: The action performed by the user.\n    \"\"\"\n    timestamp = datetime.now().strftime('%Y-%m-%d %H:%M:%S')\n    log_message = f\"User {user_id} performed action: {action}\"\n    logging.info(log_message)\n    print(f\"Logged: {log_message} at {timestamp}\")"
    },
    {
        "file_name": "user_activity.py",
        "file_content": "from logger import log_activity\n\ndef record_login(user_id):\n    \"\"\"\n    Records a user login event.\n\n    :param user_id: The ID of the user logging in.\n    \"\"\"\n    log_activity(user_id, \"login\")\n\ndef record_logout(user_id):\n    \"\"\"\n    Records a user logout event.\n\n    :param user_id: The ID of the user logging out.\n    \"\"\"\n    log_activity(user_id, \"logout\")\n\ndef record_action(user_id, action):\n    \"\"\"\n    Records a general user action.\n\n    :param user_id: The ID of the user performing the action.\n    :param action: The action performed by the user.\n    \"\"\"\n    log_activity(user_id, action)"
    },
    {
        "file_name": "main.py",
        "file_content": "from user_activity import record_login, record_logout, record_action\n\ndef main():\n    # Example usage\n    user_id = \"user123\"\n    record_login(user_id)\n    record_action(user_id, \"viewed profile\")\n    record_action(user_id, \"edited settings\")\n    record_logout(user_id)\n\nif __name__ == \"__main__\":\n    main()"
    }
]