/
Working with Hitachi HCP

Working with Hitachi HCP

HCP is an affordable on-premise alternative to Amazon S3. At Indiana we're looking at using it for our deployment, specifically to avoid being tied to a shared file system.

Configuration

If you're using Avalon 7+, these settings need to point to HCP:

config/settings.yml
 minio:
   endpoint: http://hcp.internal.example.edu
   public_host: http://hcp.external.example.edu # if different from endpoint
   access: <access key>
   secret: <secret key>

 Problem

aws-sdk Ruby implementation appends an Accept-Encoding="" header to every request, which HCP doesn't accept. We need to change this header to Accept-Encoding="identity" for all but the presigned URLs. The following code requires aws-sdk v3 to work.

config/initializer/aws.rb
  # Add header for HCP compatibility
  module Seahorse
    module Client
      module Plugins
        class AcceptEncoding < Plugin

          # @api private
          class Handler < Client::Handler

            def call(context)
              context.http_request.headers['Accept-Encoding'] = 'identity'
              @handler.call(context)
            end
          end

          handler(Handler, step: :sign, priority: 0)
        end
      end
    end
  end

  Aws::S3::Client.add_plugin Seahorse::Client::Plugins::AcceptEncoding

  # Exclude this header from the signature calculation otherwise S3 will not accept the presigned_url
  Aws::S3::Presigner::BLACKLISTED_HEADERS = Aws::S3::Presigner::BLACKLISTED_HEADERS + ["accept-encoding"]