Skip to main content

A FastAPI wrapper for the folder_manager package, providing a RESTful API for managing folders and files.

Project description

Folder Manager API

folder_manager_api is a FastAPI wrapper for the folder_manager package, providing a RESTful API for managing folders and files.

Features:

  • Create and delete folders
  • List files in a folder
  • Count files in a folder
  • Create and delete files
  • Check if a folder or file exists
  • List and count files with specific extensions
  • Basic authentication
  • Logging functionality

Installation:

You can install folder_manager_api using pip:

pip install folder_manager_api

Usage:

To run the API server:

folder_manager_api

or

python -m folder_manager_api

This will start the server on http://localhost:8000.

API Endpoints and Sample Requests:

  1. GET /: Health check endpoint

    curl -X GET http://localhost:8000/
    
  2. POST /create_folder/: Create a new folder

    curl -X POST http://localhost:8000/create_folder/ -H "Content-Type: application/json" -d '{"path": "/path/to/new/folder"}'
    
  3. POST /list_files/: List files in a folder

    curl -X POST http://localhost:8000/list_files/ -H "Content-Type: application/json" -d '{"path": "/path/to/folder"}'
    
  4. POST /list_files_with_extension/: List files with a specific extension

    curl -X POST http://localhost:8000/list_files_with_extension/ -H "Content-Type: application/json" -d '{"path": "/path/to/folder", "extension": ".txt"}'
    
  5. POST /count_files/: Count files in a folder

    curl -X POST http://localhost:8000/count_files/ -H "Content-Type: application/json" -d '{"path": "/path/to/folder"}'
    
  6. POST /count_files_with_extension/: Count files with a specific extension

    curl -X POST http://localhost:8000/count_files_with_extension/ -H "Content-Type: application/json" -d '{"path": "/path/to/folder", "extension": ".txt"}'
    
  7. POST /create_file/: Create a new file

    curl -X POST http://localhost:8000/create_file/ -H "Content-Type: application/json" -d '{"path": "/path/to/folder", "file_name": "newfile.txt", "content": "Hello, World!"}'
    
  8. POST /delete_file/: Delete a file

    curl -X POST http://localhost:8000/delete_file/ -H "Content-Type: application/json" -d '{"path": "/path/to/folder", "file_name": "file_to_delete.txt"}'
    
  9. POST /delete_folder/: Delete a folder

    curl -X POST http://localhost:8000/delete_folder/ -H "Content-Type: application/json" -d '{"path": "/path/to/folder/to/delete"}'
    
  10. POST /folder_exists/: Check if a folder exists

    curl -X POST http://localhost:8000/folder_exists/ -H "Content-Type: application/json" -d '{"path": "/path/to/check"}'
    
  11. POST /file_exists/: Check if a file exists

    curl -X POST http://localhost:8000/file_exists/ -H "Content-Type: application/json" -d '{"path": "/path/to/folder", "file_name": "file_to_check.txt"}'
    

Note: All endpoints require basic authentication. Add -u username:password to your curl commands or use appropriate authentication in your HTTP client.

Configuration:

The API can be configured using a folder_manager_api.config file. If not present, a default configuration will be created.

Sample configuration file (folder_manager_api.config):

[server]
port = 8000

[auth]
username = admin
password = password

[logging]
log_size = 1073741824

Configuration details:

  1. server section:
    • port: The port number on which the API server will run. Default is 8000.
  2. auth section:
    • username: The username for basic authentication.
    • password: The password for basic authentication.
  3. logging section:
    • log_size: Maximum size of the log file in bytes before it rotates. Default is 1073741824 (1GB).

You can modify these values to customize the API's behavior. If the configuration file is not present when the API starts, it will create a default one with these values.

Logging:

The API logs all requests and responses to a file named folder_manager_api.log. The log file uses a rotating file handler, which means it will create new log files and archive old ones when the file size limit (specified in log_size) is reached.

Dependencies:

  • fastapi
  • uvicorn
  • pydantic
  • folder_manager

License:

This project is licensed under the MIT License.

Author:

Javer Valino

Links:

GitHub: https://github.com/phintegrator/folder_manager_api

Contributing:

Contributions are welcome! Please feel free to submit a Pull Request.

Support:

If you encounter any problems or have any questions, please open an issue on the GitHub repository.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

folder_manager_api-1.0.1.tar.gz (5.0 kB view details)

Uploaded Source

Built Distribution

folder_manager_api-1.0.1-py3-none-any.whl (5.8 kB view details)

Uploaded Python 3

File details

Details for the file folder_manager_api-1.0.1.tar.gz.

File metadata

  • Download URL: folder_manager_api-1.0.1.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for folder_manager_api-1.0.1.tar.gz
Algorithm Hash digest
SHA256 3bfa9b64929df4232b761078934d748d7900a5a429c39a9d9ddcae602f1d5ab7
MD5 f6d1587ecb225df15b26fa08cd025617
BLAKE2b-256 2aca768f84b7787d88b45f88c93d37ecf93157c5783e7529b0b098022d341a1d

See more details on using hashes here.

File details

Details for the file folder_manager_api-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for folder_manager_api-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 cb14ccbda2845d82c9e529dc102f18d050b29b2ea7d61d0690f5e1cfbe1e1c7d
MD5 5aa776fd1f13552d5abf5540064b3244
BLAKE2b-256 3c218f8191e906ed696c0d8f86922ec14966641a9986d51bb5d6a081add4fb61

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page