Skip to content

Latest commit

 

History

History
442 lines (344 loc) · 10.7 KB

README.md

File metadata and controls

442 lines (344 loc) · 10.7 KB

Prëxis API

Authentication

POST https://prexis.io/api/v1/auth

Returns the JWT token.

Parameters:

Parameter Name Parameter Value
key The client key provided by Prëxis
password Password provided by Prëxis

Response examples:

Valid credentials:

{
  "code": 200,
  "status": "success",
  "message": "Valid login credentials",
  "key": "<client key>",
  "jwt": "<jwt token>",
  "cached": "<true | false>"
}

Invalid credentials:

{
  "code": 0,
  "status": "error",
  "message": "No match found (<internal error code>)"
}

Insuficient credentials:

{
  "code": 0,
  "status": "error",
  "message": "Data missing"
}

Important:

  • The jwt token returned string is used to make the API requests;
  • The jwt token has to be used 01 (one) second after the response to avoid service misuse;
  • These token last for 5 minutes (300 seconds), after that, it's necessary to renew it;
  • The chached response is for internal use only.

How to use JWT token

The token must be in the header of every request.

Example:

curl --header "Authorization: Bearer <jwt token>" http://prexis.io/api/v1/credits

Please notice the space between the Bearer string and the jwt token.

If the token value has been manipulated, any request will give the following response:

{
  "code": 0,
  "status": "error",
  "message": "Authentication failed: Signature verification failed"
}

If the token has expired:

{
  "code": 0,
  "status": "error",
  "message": "Authentication failed: Expired token"
}

If the token has been used too soon:

{
  "code": 0,
  "status": "error",
  "message": "Authentication failed: Cannot handle token prior to YYYY-MM-DDTHH:MM:SS+0000"
}

Credit Balance

GET https://prexis.io/api/v1/credits

Returns the credit balance.

Parameters:

None.

Header:

Header Name Header Value
Authorization Bearer <jwt token>

Response example:

{
  "code": 200,
  "status": "success",
  "key": "<client key>",
  "current_time": 1535980547,
  "result": {
    "rescode": 200,
    "message": "Operation successfull",
    "credits": 10
  }
}

Registering a Hash

POST https://prexis.io/api/v1/registerhash

Registers a valid SHA256 hash in Ethereum blockchain.

Parameters:

Parameter Name Parameter Value
hash A valid SHA256 hash string without the 0x prefix
email E-mail address to send the confirmation (optional)

Header:

Header Name Header Value
Authorization Bearer <jwt token>

Response examples:

Successfull request:

{
  "code": 200,
  "status": "success",
  "key": "<client key>",
  "current_time": 1535980723,
  "result": {
    "credits": 9,
    "rescode": 200,
    "message": "Operation successfull",
    "hash": "6aaf8f326d9d27d212e8647cbd1306dc1687f90595d0e6821e274d4d6312c387"
  }
}

Hash already registered:

{
  "code": 200,
  "status": "success",
  "key": "<client key>",
  "current_time": 1535980752,
  "result": {
    "rescode": 402,
    "message": "Hash already registered",
    "hash": "6aaf8f326d9d27d212e8647cbd1306dc1687f90595d0e6821e274d4d6312c387"
  }
}

Invalid SHA256 hash format:

{
  "code": 200,
  "status": "success",
  "key": "<client key>",
  "current_time": 1535980784,
  "result": {
    "rescode": 401,
    "message": "Invalid SHA256 hash format",
    "hash": "<invalid hash>"
  }
}

Registering a Document

POST https://prexis.io/api/v1/registerdoc

Registers a document hash in Ethereum blockchain and generates a unique link to download the file via IPFS and HTTPS.

Parameters:

Parameter Name Parameter Value
file A binary file (Content-Type: multipart/form-data)
email E-mail address to send the confirmation (optional)

Header:

Header Name Header Value
Authorization Bearer <jwt token>

Response examples:

Successfull request:

{
	"code": 200,
	"status": "success",
	"current_time": 1539137849,
	"result": {
		"credits": 9,
		"rescode": 200,
		"message": "Operation successfull",
		"hash": "ef1df95706603b4130d4a765906b42109fdb527fc49a1884f012c884c10c0ad9",
		"ipfs": "QmPrcEGofvSt8kMrjSkp8cYuDY91JaiPmHgJ3i1MitsDZn"
	}
}

Document hash already registered:

{
  "code": 200,
  "status": "success",
  "key": "<client key>",
  "current_time": 1535980752,
  "result": {
    "rescode": 402,
    "message": "Hash already registered",
    "hash": "6aaf8f326d9d27d212e8647cbd1306dc1687f90595d0e6821e274d4d6312c387"
  }
}

Empty or invalid file:

{
  "code": 200,
  "status": "success",
  "current_time": 1539078269,
  "result": {
    "rescode": 405,
    "message": "File is empty"
  }
}

Get Blockchain Transaction

POST https://prexis.io/api/v1/transaction

Returns the transactions info, like transaction and block hashes, block number, timestamp, etc.

Parameters:

Parameter Name Parameter Value
hash A valid SHA256 hash string without the 0x prefix

Header:

Header Name Header Value
Authorization Bearer <jwt token>

Response examples:

Transaction already mined in a block without document (only hash):

{
  "code": 200,
  "status": "success",
  "key": "<client key>",
  "current_time": 1535981729,
  "result": {
    "transaction": {
      "blockHash": "0xa74ef377e2b8f889390c6c2168c5dbd26533741123d3f0ad097607538fb6a14e",
      "blockNumber": 3965065,
      "blockchainUrl": "https://ropsten.etherscan.io/tx/0x3d0da45eeea6e5acf29a79b16d34dd565709a3874646f50ec60339345aead806",
      "cumulativeGasUsed": 10538243,
      "from": "0xd8f7e3adb3c93739b2600e7180d2dfaecfa3b4e9",
      "gasUsed": 23176,
      "timestamp": 1535980696,
      "transactionHash": "0x3d0da45eeea6e5acf29a79b16d34dd565709a3874646f50ec60339345aead806",
      "transactionIndex": 26
    },
    "rescode": 200,
    "message": "Operation successfull",
    "hash": "6aaf8f326d9d27d212e8647cbd1306dc1687f90595d0e6821e274d4d6312c387"
  }
}

Transaction already mined in a block with document:

{
  "code": 200,
  "status": "success",
  "current_time": 1539081946,
  "result": {
  "doc": {
    "ipfs": "QmSFVQjx6nB69BELd8PFn3WUhWm6YwGAkbZUyfeeoAxejR",
    "mimetype": "image\/png",
    "original": "television-3.png",
    "path": "docs\/e9f68371c915bdfd113c47651095aed44f4f1ac92f4af673624c97f1e696d43d",
    "sha256": "e9f68371c915bdfd113c47651095aed44f4f1ac92f4af673624c97f1e696d43d",
    "size": 46696
  },
  "transaction": {
    "blockHash": "0x8c5efe643d01edbba1066f44cb080db1ccfcf8dcb81283c95136cf06496b30fa",
    "blockNumber": 6482269,
    "blockchainUrl": "https:\/\/etherscan.io\/tx\/0xfd960506052311615271cc56cdb78077ca1da79f9318b481b17d56b5f6a9a034",
    "cumulativeGasUsed": 5753996,
    "from": "0xe7b703865cd59a11dce5faff675f61da233b9bbe",
    "gasUsed": 23176,
    "timestamp": 1539081708,
    "transactionHash": "0xfd960506052311415271cc56cdb78077ca1da79f9318b481b17d56b5f6a9a034",
    "transactionIndex": 129
  },
  "rescode": 200,
   "message": "Operation successfull",
   "hash": "e9f68371c915bdfd113c47651095aed44f4f1ac92f4af673624c97f1e696d43d"
  }
}

Transaction pending (waiting for be mined):

{
  "code": 200,
  "status": "success",
  "key": "<client key>",
  "current_time": 1535981729,
  "result": {
    "transaction": {
      "blockchainUrl": "https://ropsten.etherscan.io/tx/0x3d0da45eeea6e5acf29a79b16d34dd565709a3874646f50ec60339345aead806",
      "transactionHash": "0x3d0da45eeea6e5acf29a79b16d34dd565709a3874646f50ec60339345aead806",
    },
    "rescode": 200,
    "message": "Operation successfull",
    "hash": "6aaf8f326d9d27d212e8647cbd1306dc1687f90595d0e6821e274d4d6312c387"
  }
}

Transaction not yet submitted:

{
  "code": 200,
  "status": "success",
  "key": "<client key>",
  "current_time": 1535981729,
  "result": {
    "transaction": {
      "transactionHash": "wait",
    },
    "rescode": 200,
    "message": "Operation successfull",
    "hash": "6aaf8f326d9d27d212e8647cbd1306dc1687f90595d0e6821e274d4d6312c387"
  }
}

Invalid SHA256 hash format:

{
  "code": 200,
  "status": "success",
  "key": "<client key>",
  "current_time": 1535981729,
  "result": {
    "rescode": 401,
    "message": "Invalid SHA256 hash format",
    "hash": "<invalid hash>"
  }
}

Hash not registered with Prëxis:

{
  "code": 200,
  "status": "success",
  "key": "cK19vqzgqB2",
  "current_time": 1535981729,
  "result": {
    "rescode": 403,
    "message": "Hash not registered",
    "hash": "6baf8f326d9d27d212e8647cbd1306dc1687f90595d0e6821e274d4d6312c387"
  }
}

Rate limits

Prëxis API have rate limits that cap the number of requests that can be made against an endpoint in a hour. If you exceed the rate limit, your request will be throttled and you will receive HTTP 429 Too Many Requests responses from the API.

You can check your rate limit reading the response header:

Response Header:

Header Name Header Value
X-RateLimit-Limit Limit
X-RateLimit-Remaining Your current remaining requests