Skip to content

Latest commit

 

History

History
236 lines (211 loc) · 6.97 KB

README.md

File metadata and controls

236 lines (211 loc) · 6.97 KB

Cloud Connector

Connect to various cloud storage providers, transfer files between them or upload.

How to start application

If using pre-built executable binary from ./builds directory, navigate to the project root directory (where main.go resides) start application in the command line as follows:
./builds/builds/cloud-connector-ubuntu64

The application will start using the default port 3000. If a different port is required supply the port number as argument:
./builds/builds/cloud-connector-ubuntu64 8080

Start demo webpage

The application also includes HTML files for demonstration/test purposes only. The demo webpage allows the user to test the /upload function and directly upload to an AWS S3 bucket. To start the application in demo mode:
./builds/builds/cloud-connector-ubuntu64 8080 demo

The webpage can be accessed from any browser on the local machine here: http://localhost:8080 (change port if different)

How to build

Building Cloud Connector requires Golang application to be installed and GOROOT & GOPATH set up properly. If you haven't already, do so by follwoing instructions from http://golang.org.

Now retrieve dependent packages required by the application.

go get -v github.com/graymeta/stow
go get -v github.com/graymeta/stow/azure
go get -v github.com/graymeta/stow/google
go get -v github.com/graymeta/stow/s3

After that navigate to the project root directory and run the following command:
go build -o builds/cloud-connector

PS: By default Cloud Connector is supports the following providers: Google Cloud Storage, Amazon AWS S3, Microsoft Azure. However, the Stow project supports other providers such as B2, Swift and Oracle. If support for those are required, 1) import the required packages in the Storage.go file and retrieve the package by runnig the go get command rebuild the executable binary as mentioned above.

API Guideline

Below are the API endpoints for the Cloud Connector.
Expected response codes:

Success                     : 200 - ok
File Creation               : 201 - created
Error caused by input data  : 400 - bad request
Other errors                : 500 - internal server error

/dial - POST

Validate credentials by dialing a connection to cloud storage provider.

JSON Body:
{
    "kind": "",    // s3, google, azure
    "config_map": {
        // depends on the value provided in "kind"
        // see "config_map" below for specifics 
    }
}
Success Response - Status Code 200
{
    "success": true
}

/container - POST

Lists containers from a specific provider

JSON Body:
{
    "kind": "",    // s3, google, azure
    "cursor": "",  // for pagination
    "count": 0,    // number of items to retrieve. 0 for all items
    "config_map": {
        // depends on the value provided in "kind"
        // see "config_map" below for specifics 
    }
}
Success Response - Status Code 200
{
    "cursor": "",
    "count": 1,
    "containers": {
        "container1ID": "container1Name",
        "container2ID": "container2Name",
        ...
    }
}

/items - POST

Lists objects/files from a specific container/bucket

JSON Body:
{
    "kind": "",
    "container_name": "", // Name of the container/bucket
    "cursor": "",
    "count": 100,
    "config_map": {
    }
}
Success Response - Status Code 200
{
    "cursor": "test/Faxee/scripts/i18n/angular-locale_en-bz.js",
    "count": 99,
    "items": [
        {
            "id": "path/to/file.jpg",
            "name": "path/to/file.jpg",
            "size": 0,
            "url": "https://s3-ap-southeast-2.amazonaws.com/bucket/path/to/file.jpg",
            "metadata": {}
        },
        ...
    ]
}

/copy - POST

Transfer a single file from one provider to another. For multiple files, invoke separately

JSON Body:
{
    "from": {
        "kind": "",
        "container_name": "", // Source container
        "item_id": "path/to/file.jpg",
        "config_map": {
        }
    },
    "to": {
        "kind": "",
        "container_name": "", // Destination container
        "item_name": "new/path/to/uploaded-file.jpg", // Optional
        "config_map": {
        }
    }
}
Success Response - Status Code 201
{
    "id": "new/path/to/uploaded-file.jpg",
    "name": "new/path/to/uploaded-file.jpg",
    "size": 58533,
    "url": "https://s3-us-east-1.amazonaws.com/bucket/new/path/to/uploaded-file.jpg",
    "metadata": {}
}

/upload - POST

Upload file directly to container. The request must be created using Form Data. Refer to /public/index.html for example.

Form Data:
{
    "file": (file binary),
    "to": {
        "kind": "",
        "container_name": "",
        "item_name": "optional/new/path/to/uploaded-file.jpg",
        "config_map": {
        }
    }
}
Success Response - Status Code 201
{
    "id": "new/path/to/uploaded-file.jpg",
    "name": "new/path/to/uploaded-file.jpg",
    "size": 58533,
    "url": "https://s3-us-east-1.amazonaws.com/bucket/new/path/to/uploaded-file.jpg",
    "metadata": {}
}

/getjsonstring

Returns supplied JSON object/array as a single string value by escaping required characters. Can be usesful for the "json" attribute of the "config_map" for connecting to Google Cloud Storage account.

JSON Body:
{
    "key1": "value",
    "key2": "value",
    "key3": "value"
}
Success Response: Status Code 200
"{\"key1\":\"value\",\"key2\":\"value\",\"key3\":\"value\"}"

config_map

config_map properties for different providers

config_map for AWS S3

{
    "access_key_id": "",
    "secret_key":   "",
    "region":      "us-east-1"
}

config_map for Google Cloud Storage

{
    "project_id": "", // project id
    "json":""         // entire json file downloaded from Google as string with double quotes escaped using backslash. If unsure use the API function "/getjsonstring" below
}

If you are not sure what/how to use Google credentials follow the steps below:

  1. Login to google cloud console 2.Go to menu (top left)>> IAM & Admin >> Service accounts
  2. Create a new service account (account that can access your GCloud storage). Fill up the form and submit.
  3. Then on the next step you can assign a role(recommended). From "Storage" at the bottom of roles list select either "Admin" or "Object Admin" for now ("creator" for write only access, "viewer" for read only access)
  4. On the next step click "create key" then select "json" and click create to down the json file
  5. Copy the entire content of the json file and convert it to text by using the /getjsonstring API.
  6. Now use it inside config_map on the "json" attribute.

config_map for Azure

{
    "account": "",
    "key":   ""
}

config_map for other providers

Please refer to the supported providers https://github.com/graymeta/stow. Required config_map attributes can be found in the confg.go file of the respective package insite the "const" declarations