1
0
mirror of https://github.com/oceanprotocol/commons.git synced 2023-03-15 18:03:00 +01:00
commons/server
Jernej Pregelj fde6a42a21 merge
2019-08-06 16:40:10 +02:00
..
src
test
.env.example
Dockerfile
package-lock.json merge 2019-08-06 16:40:10 +02:00
package.json bump packages 2019-07-31 11:45:00 +02:00
README.md
tsconfig.json

banner

Commons: Server

This folder contains server component written in TypeScript using Express. The server provides various microservices.

Get Started

To spin up the server in a watch mode for local development, execute:

npm install
npm start

API Documentation

Url Checker

Url Checker returns size and additional information about requested file. This service is used as a solution to frontend CORS restrictions.

Endpoint: POST /api/v1/urlcheck

Request Parameters

{
  "url": "https://oceanprotocol.com/tech-whitepaper.pdf"
}

Response: Success

{
  "status": "success",
  "result": {
    "found": true,
    "contentLength": "2989228",
    "contentType": "application/pdf"
  }
}

Response: Error

{
  "status": "error",
  "message": null
}

Report

Report endpoints sends an email via SendGrid. Requires SENDGRID_API_KEY set as environment variables.

Endpoint: POST /api/v1/report

Request Parameters

{
  "msg": {
    "to": "test@example.com",
    "from": "test@example.com",
    "subject": "My Subject",
    "text": "Text",
    "html": "<strong>HTML</strong>"
  }
}

Response: Success

{
  "status": "success"
}

Response: Error

{
  "status": "error",
  "message": "Error message"
}

🎁 Contributing

See the page titled "Ways to Contribute" in the Ocean Protocol documentation.

🏛 License

Copyright 2019 Ocean Protocol Foundation Ltd.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.