2018-10-17 18:24:01 +02:00
|
|
|
import * as EthEcies from "eth-ecies"
|
2018-10-18 13:06:52 +02:00
|
|
|
import * as JWT from "jsonwebtoken"
|
2018-10-25 17:26:26 +02:00
|
|
|
import AquariusProvider from "../aquarius/AquariusProvider"
|
2018-10-16 14:56:18 +02:00
|
|
|
import Keeper from "../keeper/Keeper"
|
2018-10-18 13:06:52 +02:00
|
|
|
import Web3Provider from "../keeper/Web3Provider"
|
2018-10-17 18:24:01 +02:00
|
|
|
import AccessStatus from "../models/AccessStatus"
|
2018-10-02 10:06:26 +02:00
|
|
|
import Logger from "../utils/Logger"
|
2018-10-16 15:08:04 +02:00
|
|
|
import Account from "./Account"
|
2018-10-16 14:56:18 +02:00
|
|
|
import Asset from "./Asset"
|
2018-10-09 10:55:53 +02:00
|
|
|
import OceanBase from "./OceanBase"
|
2018-10-01 18:10:26 +02:00
|
|
|
|
2018-10-09 10:55:53 +02:00
|
|
|
export default class Order extends OceanBase {
|
2018-10-01 18:10:26 +02:00
|
|
|
|
2018-10-16 14:56:18 +02:00
|
|
|
constructor(private asset: Asset, private timeout: number,
|
|
|
|
private pubkey: string, private key: any) {
|
|
|
|
super()
|
2018-10-01 18:10:26 +02:00
|
|
|
}
|
|
|
|
|
2018-10-17 18:24:01 +02:00
|
|
|
public async getStatus(): Promise<AccessStatus> {
|
|
|
|
const {auth} = await Keeper.getInstance()
|
|
|
|
return auth.getOrderStatus(this.id)
|
2018-10-16 14:56:18 +02:00
|
|
|
}
|
2018-10-01 18:10:26 +02:00
|
|
|
|
2018-10-17 18:24:01 +02:00
|
|
|
public async pay(consumer: Account): Promise<string> {
|
2018-10-16 14:56:18 +02:00
|
|
|
const {market} = await Keeper.getInstance()
|
2018-10-17 18:24:01 +02:00
|
|
|
Logger.log(
|
|
|
|
`Sending payment: ${this.getId()} ${this.asset.publisher.getId()} ${this.asset.price} ${this.timeout}`,
|
|
|
|
)
|
2018-10-18 13:06:52 +02:00
|
|
|
const payReceipt =
|
|
|
|
await market.payOrder(this, this.asset.publisher.getId(), this.asset.price, consumer.getId(), this.timeout)
|
2018-10-17 10:12:40 +02:00
|
|
|
|
|
|
|
return payReceipt.events.PaymentReceived.returnValues._paymentId
|
2018-10-01 18:10:26 +02:00
|
|
|
}
|
2018-10-17 18:24:01 +02:00
|
|
|
|
2018-10-18 13:06:52 +02:00
|
|
|
public async commit(accessToken: string): Promise<boolean> {
|
2018-10-17 18:24:01 +02:00
|
|
|
const {auth} = await Keeper.getInstance()
|
|
|
|
const commitAccessRequestReceipt = await auth.commitAccessRequest(this, this.asset.publisher.getId())
|
|
|
|
if (commitAccessRequestReceipt.events.AccessRequestRejected) {
|
|
|
|
|
|
|
|
const {returnValues} = commitAccessRequestReceipt.events.AccessRequestRejected
|
|
|
|
throw new Error(`commitAccessRequest failed ${JSON.stringify(returnValues, null, 2)}`)
|
|
|
|
}
|
|
|
|
|
|
|
|
const pubKey = await auth.getTempPubKey(this.getId())
|
|
|
|
|
|
|
|
if (this.pubkey !== pubKey) {
|
|
|
|
throw new Error("Pubkey missmatch")
|
|
|
|
}
|
|
|
|
|
|
|
|
const encryptedAccessToken =
|
|
|
|
EthEcies.encrypt(new Buffer(pubKey, "hex"), new Buffer(accessToken)).toString("hex")
|
|
|
|
|
|
|
|
await auth.deliverAccessToken(this.getId(), `0x${encryptedAccessToken}`, this.asset.publisher.getId())
|
2018-10-18 13:06:52 +02:00
|
|
|
|
|
|
|
return true
|
2018-10-17 18:24:01 +02:00
|
|
|
}
|
2018-10-18 13:06:52 +02:00
|
|
|
|
|
|
|
public async consume(consumer: Account): Promise<string> {
|
|
|
|
const {auth} = await Keeper.getInstance()
|
|
|
|
|
|
|
|
const encryptedAccessToken = await auth.getEncryptedAccessToken(this.getId(), consumer.getId())
|
|
|
|
|
|
|
|
// grab the access token from acl contract
|
|
|
|
const tokenNo0x = encryptedAccessToken.slice(2)
|
|
|
|
const encryptedTokenBuffer = Buffer.from(tokenNo0x, "hex")
|
|
|
|
|
|
|
|
const privateKey = this.key.privateKey.slice(2)
|
|
|
|
const accessTokenEncoded: string =
|
|
|
|
EthEcies.decrypt(Buffer.from(privateKey, "hex"), encryptedTokenBuffer).toString()
|
|
|
|
const accessToken = JWT.decode(accessTokenEncoded) // Returns a json object
|
|
|
|
|
|
|
|
if (!accessToken) {
|
|
|
|
throw new Error(`AccessToken is not an jwt: ${accessTokenEncoded}`)
|
|
|
|
}
|
|
|
|
|
|
|
|
const signature = Web3Provider.getWeb3().eth.sign(encryptedAccessToken, consumer.getId())
|
|
|
|
const encryptedAccessTokenSha3 = Web3Provider.getWeb3().utils.sha3(encryptedAccessToken)
|
|
|
|
|
|
|
|
// Download the data set from the provider using the url in the access token
|
|
|
|
// decode the access token, grab the service_endpoint, request_id,
|
|
|
|
|
|
|
|
// payload keys: ['consumerId', 'fixed_msg', 'sigEncJWT', 'jwt']
|
|
|
|
const payload = JSON.stringify({
|
|
|
|
consumerId: consumer.getId(),
|
|
|
|
fixed_msg: encryptedAccessTokenSha3,
|
|
|
|
sigEncJWT: signature,
|
|
|
|
jwt: accessTokenEncoded,
|
|
|
|
})
|
|
|
|
|
2018-10-25 17:26:26 +02:00
|
|
|
const accessUrl = await AquariusProvider.getAquarius().getAccessUrl(accessToken, payload)
|
2018-10-18 13:06:52 +02:00
|
|
|
|
|
|
|
Logger.log("consume url: ", accessUrl)
|
|
|
|
|
|
|
|
return accessUrl
|
|
|
|
}
|
|
|
|
|
2018-10-01 18:10:26 +02:00
|
|
|
}
|