Skip to content

Latest commit

 

History

History
453 lines (314 loc) · 22.5 KB

README.md

File metadata and controls

453 lines (314 loc) · 22.5 KB

BLOOCK Managed API

The BLOOCK Managed API is a tool to integrate BLOOCK's services using an API instead of our SDKs by taking care of all the integration logic:


Table of Contents


Installation

You have two primary methods to set up and run the Bloock Managed API:

  1. Docker Setup Guide
  2. Standalone Setup

Each method has its advantages and use cases.

Docker Setup Guide

Docker offers a convenient way to package and distribute the API, along with its required dependencies, in a self-contained environment. It's an excellent choice if you want a quick and hassle-free setup, or if you prefer isolation between your application and the host system.

Option 1: Pull and Run the Docker Image

This option is straightforward and ideal if you want to get started quickly. Follow these steps:

  1. Pull the Docker Image:

    • Open your terminal or command prompt.

    • Run the following command to pull the Docker image from DockerHub:

      docker pull bloock/managed-api

      This command fetches the latest version of the Bloock Managed API image from DockerHub. We maintain a Docker repository with the latest releases of this repository.

  2. Create a .env File:

    • In your project directory, create a .env file. You can use a text editor of your choice to create this file.

    • This file will contain the configuration for the API, including environment variables. Refer to the Variables section for a list of environment variables and their descriptions.

    • In the .env file, define the environment variables you want to configure for the API. Each environment variable should be set in the following format:

      VARIABLE_NAME=VALUE
    • Here's an example of what your .env file might look like:

      BLOOCK_DB_CONNECTION_STRING=file:bloock?mode=memory&cache=shared&_fk=1
      BLOOCK_BLOOCK_API_KEY=your_api_key
      BLOOCK_BLOOCK_WEBHOOK_SECRET_KEY=your_webhook_secret_key
      BLOOCK_WEBHOOK_CLIENT_ENDPOINT_URL=https://bloock.com/endpoint/to/send/file

      NOTE: For the BLOOCK_DB_CONNECTION_STRING environment variable, you have the flexibility to specify your own MySQL or PostgreSQL infrastructure. Clients can provide their connection string for their database infrastructure. See the Database section for available connections.

  3. Run the Docker Image with Environment Variables:

    • Run the following command to start the Bloock Managed API container while passing the .env file as an environment variable source:
    docker run --env-file .env -p 8080:8080 bloock/managed-api
    • This command maps the .env file into the container, ensuring that the API reads its configuration from the file. Viper automatically read these environment variables and make them accessible to the code.

    • By default, the above command runs the Docker container in the foreground, displaying API logs and output in your terminal. You can interact with the API while it's running.

      3.1. Running Docker in the Background (Daemon Mode)

    • Append the -d flag to the docker run command as follows:

    docker run -d --env-file config.txt -p 8080:8080 bloock/managed-api

    The -d flag tells Docker to run the container as a background process. You can continue using your terminal for other tasks while the Bloock Managed API container runs silently in the background.

  4. Access the API:

    • After running the Docker image, the Bloock Managed API will be accessible at http://localhost:8080.

    • You can now make API requests to interact with the service.

By following these steps, you can quickly deploy the Bloock Managed API as a Docker container with your customized configuration.

Option 2: Use Docker Compose with Database Containers

If you need a more complex setup, such as using a specific database like MySQL, Postgres or MemDB, Docker Compose is your choice. Follow these steps:

  1. Choose the Docker Compose File:

    • In our repository, you will find Docker Compose files for different database types:

      • docker-compose-mysql.yaml for MySQL
      • docker-compose-postgres.yaml for PostgreSQL
      • docker-compose.yaml for MemDB (SQLite)
  2. Copy the Chosen Docker Compose File:

    • Choose the Docker Compose file that corresponds to the database type you want to use. For example, if you prefer MySQL, copy docker-compose-mysql.yaml.
  3. Configure Environment Variables:

    • Open the Docker Compose file in a text editor. Inside the file, locate the environment section for the api service. Here, you can specify environment variables that configure the API.

    • Refer to the Variables section for a list of environment variables and their descriptions.

  4. Set Environment Variables:

    • In the environment section, you can set environment variables in the following format:

      VARIABLE_NAME: "VALUE"
    • Here's an example of what your environment section might look like:

      BLOOCK_DB_CONNECTION_STRING: "file:bloock?mode=memory&cache=shared&_fk=1"
      BLOOCK_BLOOCK_API_KEY: "your_api_key"
      BLOOCK_BLOOCK_WEBHOOK_SECRET_KEY: "your_webhook_secret_key"
      BLOOCK_WEBHOOK_CLIENT_ENDPOINT_URL: "https://bloock.com/endpoint/to/send/file"
  5. Run Docker Compose:

    • Open your terminal, navigate to the directory where you saved the Docker Compose file, and run the following command:
     docker-compose -f docker-compose-mysql.yaml up

    Replace docker-compose-mysql.yaml with the name of the Docker Compose file you selected.

    5.1. Running Docker in the Background (Daemon Mode)

    • Append the -d flag to the docker run command as follows:
    docker-compose -f docker-compose-mysql.yaml up -d

    The -d flag tells Docker to run the container as a background process. You can continue using your terminal for other tasks while the Bloock Managed API container runs silently in the background.

  6. Access the API:

    • After running the Docker Compose command, the Bloock Managed API will be accessible at http://localhost:8080. You can make API requests to interact with the service.

By following these steps, you can quickly set up the Bloock Managed API with your chosen database type using the provided Docker Compose files.

Standalone Setup

Running the API as a standalone application provides more control and flexibility, allowing you to customize and integrate it into your specific environment. Choose this option if you have specific requirements or if you want to modify the API's source code.

Option 3: Clone the GitHub Repository

You can also run this service as a common Golang binary if you need it.

Standalone Requirements

  • Makefile toolchain
  • Unix-based operating system (e.g. Debian, Arch, Mac OS X)
  • Go 1.20

To deploy the API as a standalone application, follow these steps:

  1. Clone the Repository or Download the Latest Release:

    1.1. Clone the Repository:

    • Open your terminal and navigate to the directory where you want to clone the repository.

    • Run the following command to clone the repository:

     git clone https://github.com/bloock/managed-api.git

    Instead of cloning the repository, it's recommended to download the latest release to ensure you have the most stable and up-to-date version of the Bloock Managed API.

    1.2 Download the Latest Release:

    • Visit the repository's releases page on GitHub.

    • Look for the latest release version and select it.

    • Under the Assets section, you will find downloadable files. Choose the appropriate file for your operating system (e.g., Windows, macOS, Linux).

    • Download the selected release file to your local machine.

      1. Navigate to the Repository:

        • Change your current directory to the cloned repository or downloaded the release file:
         cd managed-api
        1. Set Up Configuration:

          • Inside the repository, you'll find a config.yaml file.

          • Open config.yaml in a text editor and configure the environment variables as needed, following the format described in the Variables section. For example:

          api: 
           host: "0.0.0.0"
           port: 8080
           debug_mode: false
          
          db:
           connection_string: "file:bloock?mode=memory&cache=shared&_fk=1"
          
          auth:
           secret: ""
          
          bloock:
           api_host: ""
           api_key: ""
           cdn_host: ""
           webhook_secret_key: ""
          
          webhook:
           client_endpoint_url: ""
           max_retries: 
          
          authenticity:
           key:
            key_type: ""
            key: ""
           certificate:
            pkcs12_path: "./"
            pkcs12_password: ""
          
          encryption:
            key:
              key_type: ""
              key: ""
            certificate:
              pkcs12_path: "./"
              pkcs12_password: ""
          
          integrity:
             aggregate_mode: false
             aggregate_worker: false
             aggregate_interval:
          
          storage:
            tmp_dir: "./tmp"
            local_strategy: "FILENAME"
            local_path: "./data"

          NOTE: Here you will not have to use the VARIABLE: value nomenclature, but you will simply have to fill in the variables you need directly, respecting the format already established.

  2. Run the Application:

    • To run the application, execute the following command:
     go run cmd/main.go

    This command will start the Bloock Managed API as a standalone application, and it will use the configuration provided in the config.yaml file.

  3. Access the API:

    • After running the application, the Bloock Managed API will be accessible at http://localhost:8080. You can make API requests to interact with the service.

Configuration

The Bloock Managed API leverages Viper, a powerful configuration management library, currently supporting environment variables and a YAML configuration file.

Variables

Here are the configuration variables used by the Bloock Managed API:

  • BLOOCK_BLOOCK_API_KEY (OPTIONAL)
    • Description: Your unique BLOOCK API key.
    • Purpose: This API key is required for authentication and authorization when interacting with the Bloock Identity Managed API. It allows you to securely access and use the API's features.
    • Create API Key
    • Required: If you don't add the API KEY here, you must add it every time you execute a request to the API.
    • Example: no9rLf9dOMjXGvXQX3I96a39qYFoZknGd6YHtY3x1VPelr6M-TmTLpAF-fm1k9Zi
  • BLOOCK_DB_CONNECTION_STRING (OPTIONAL)
    • Description: Your custom database connection URL.
    • Default: "file:bloock?mode=memory&cache=shared&_fk=1"
    • Purpose: This variable allows you to specify your own database connection string. You can use it to connect the API to your existing database infrastructure. The format depends on the database type you choose.
    • Required: When docker database container or your existing database infrastructure provided.
  • BLOOCK_BLOOCK_WEBHOOK_SECRET_KEY (OPTIONAL)
    • Description: Your BLOOCK webhook secret key.
    • Purpose: The webhook secret key is used to secure and verify incoming webhook requests. It ensures that webhook data is received from a trusted source and has not been tampered with during transmission.
    • Required: When you want to certificate data using integrity Bloock product.
    • Create webhook
    • Example: ew1b2d5qf7WeUOPy1u1CW6FXro6j5plS
  • BLOOCK_WEBHOOK_CLIENT_ENDPOINT_URL (OPTIONAL)
    • Description: An endpoint URL where you want to send processed files.
    • Purpose: This URL specifies the destination where processed files will be sent after successful verification. It can be configured to integrate with other systems or services that require the processed data.
    • Example: https://bloock.com/endpoint/to/send/file
  • BLOOCK_WEBHOOK_MAX_RETRIES (OPTIONAL)
    • Description: Number of times it will try to send your processed files.
    • Purpose: The idea is that in case the request to your set endpoint fails, the API will try to send you that file again with an exponential backoff mechanism. These algorithms allow you to define how many times you want it to try to send you the file.
    • Example: 3
  • BLOOCK_AUTH_SECRET (OPTIONAL)
    • Description: If you want to add control in your API calls with Bearer Token you can add a secret here. A Bearer token is a type of token used for authentication and authorization and is used in web applications and APIs to hold user credentials and indicate authorization for requests and access.
    • Purpose: The idea is that you can set a secret, which will be the same that you will have to pass in the headers of your requests in order to validate yourself.
    • Example: 0tEStdP(dg5=VU4iX4+7}e((HVd^ShVm
  • BLOOCK_API_HOST (OPTIONAL)
    • Description: The API host IP address.
    • Default: 0.0.0.0
    • Purpose: This variable allows you to specify the IP address on which the Bloock Managed API should listen for incoming requests. You can customize it based on your network configuration.
  • BLOOCK_API_PORT (OPTIONAL)
    • Description: The API port number.
    • Default: 8080
    • Purpose: The API listens on this port for incoming HTTP requests. You can adjust it to match your preferred port configuration.
  • BLOOCK_API_DEBUG_MODE (OPTIONAL)
    • Description: Enable or disable debug mode.
    • Default: false
    • Purpose: When set to true, debug mode provides more detailed log information, which can be useful for troubleshooting and debugging. Set it to false for normal operation.

If you do not want to use Bloock's managed key service and use your own keys locally, then you must fill in these variables in order to perform authenticity or encryption on your files:

  • BLOOCK_AUTHENTICITY_KEY_KEY (OPTIONAL)
    • Description: Private key for signing data.
    • Purpose: If you want to sign data using your own local private key, you can specify it here. This private key is used for cryptographic operations to ensure data integrity and authenticity.
    • Example: bf5e13dd8d9f784aee781b4de7836caa3499168514553eaa3d892911ad3c115t
  • BLOOCK_AUTHENTICITY_KEY_KEY_TYPE (OPTIONAL)
    • Description: Type of key.
    • Purpose: This key type is utilized for cryptographic signing processes.
    • Options: EcP256k, Rsa2048, Rsa3072, Rsa4096.
  • BLOOCK_AUTHENTICITY_CERTIFICATE_PKCS12_PATH (OPTIONAL)
    • Description: Certificate for signing data.
    • Purpose: In case you want to upload a digital certificate in pkcs12 (.pfx, .p12) format, you can specify the url where it is to be processed.
    • Example: ./my_cert.p12
  • BLOOCK_AUTHENTICITY_CERTIFICATE_PKCS12_PASSWORD (OPTIONAL)
    • Description: Certificate password.
    • Purpose: If the certificate is protected by a password, you must provide it.
  • BLOOCK_ENCRYPTION_KEY_KEY (OPTIONAL)
    • Description: Private key for encrypting data.
    • Purpose: If you want to encrypt data using your own local key, you can specify it here.
    • Example: bf5e13dd8d9f784aee781b4de7836caa3499168514553eaa3d892911ad3c115t
  • BLOOCK_ENCRYPTION_KEY_KEY_TYPE (OPTIONAL)
    • Description: Type of key.
    • Purpose: This key type is utilized for cryptographic signing processes.
    • Options: Rsa2048, Rsa3072, Rsa4096.
  • BLOOCK_ENCRYPTION_CERTIFICATE_PKCS12_PATH (OPTIONAL)
    • Description: Certificate for encrypting data.
    • Purpose: In case you want to upload a digital certificate in pkcs12 (.pfx, .p12) format, you can specify the url where it is to be processed.
    • Example: ./my_cert.p12
  • BLOOCK_ENCRYPTION_CERTIFICATE_PKCS12_PASSWORD (OPTIONAL)
    • Description: Certificate password.
    • Purpose: If the certificate is protected by a password, you must provide it.

As an advanced configuration option, users have the ability to enable the aggregator mode. Prior to enabling this feature, it is strongly advised to refer to the accompanying documentation for a comprehensive understanding of its functionality and implications. Once acquainted with the documentation, users can activate the aggregator mode by adjusting the specified variables as follows:

  • BLOOCK_INTEGRITY_AGGREGATE_MODE (OPTIONAL)
    • Description: Flag to enable the aggregator mode.
    • Default: false
    • Purpose: The process to certify a file will be changed with the aggregate feature. Basically will allow you to scale up and optimize your certifications.
  • BLOOCK_INTEGRITY_AGGREGATE_WORKER (OPTIONAL)
    • Description: Flag to enable the aggregator worker.
    • Default: false
    • Purpose: This option starts a background worker that will aggregate your certifications with a custom interval.
  • BLOOCK_INTEGRITY_AGGREGATE_INTERVAL (OPTIONAL)
    • Description: worker interval with seconds.
    • Default: 36000
    • Purpose: This option allows you to set your worker with the interval (with seconds) you need.

Finally, in case you want to store your files locally, with these variables you can edit the configuration:

  • BLOOCK_TMP_DIR (OPTIONAL)
    • Description: The temporary directory path for storing processed files.
    • Default: ./tmp
    • Purpose: Processed files can be temporarily stored in this directory while waiting for integrity confirmation. You can configure it to a specific directory path that suits your storage needs.
  • BLOOCK_STORAGE_LOCAL_PATH (OPTIONAL)
    • Description: The local directory where files will be stored when using LOCAL availability type.
    • Default: ./data
    • Purpose: Processed files will be stored in this directory only when LOCAL availability type is specified when invoking the process endpoint.
  • BLOOCK_STORAGE_LOCAL_STRATEGY (OPTIONAL)
    • Description: The filename strategy to follow when using LOCAL availability type.
    • Default: HASH
    • Purpose: Currently it supports two possible values: HASH (default) will set the file name to the content's hash and FILENAME will try to compute the file name based on the URL or the file provided (WARNING: this strategy may overwrite files if two of them compute to the same filename, i.e. uploading to files with the same name).

These configuration variables provide fine-grained control over the behavior of the Bloock Managed API. You can adjust them to match your specific requirements and deployment environment.

Database Support

The Bloock Managed API is designed to be flexible when it comes to database integration. It supports three types of relational databases: MemDB (SQLite), MySQL, and Postgres. The choice of database type depends on your specific requirements and infrastructure.

Here are the supported database types and how to configure them:

  • MySQL: To connect to a MySQL database, you can use the following connection string format
    mysql://user:password@tcp(host:port)/database
    

Replace user, password, host, port, and database with your MySQL database credentials and configuration. This format allows you to specify the MySQL database you want to connect to.

  • Postgres: For PostgreSQL database integration, use the following connection string format:

    postgres://user:password@host/database?sslmode=disable
    

Similar to MySQL, replace user, password, host, and database with your PostgreSQL database details. Additionally, you can set the sslmode as needed. The sslmode=disable option is used in the example, but you can adjust it according to your PostgreSQL server's SSL requirements.

  • MemDB (SQLite): The API also supports in-memory SQLite databases. To use SQLite, you can specify the connection string as follows:

    file:dbname?mode=memory&cache=shared&_fk=1
    

In this format, dbname represents the name of your SQLite database. The API will create an in-memory SQLite database with this name.

If you already have an existing database infrastructure and want to use it with the Bloock Managed API, you have the flexibility to provide your custom database connection string.

Variable: BLOOCK_DB_CONNECTION_STRING

The API provides a configuration variable called BLOOCK_DB_CONNECTION_STRING that allows you to specify your own database connection string independently of the way you run the API. Whether you run the API as a Docker container or as a standalone application, you can always set this variable to point to your existing database server.


Documentation

You can access the following Postman collection where is the specification for the public endpoint of this API.

Postman


License

See LICENSE.