2019-06-20 00:20:09 +02:00
|
|
|
import Account from './Account'
|
|
|
|
import { Instantiable, InstantiableConfig } from '../Instantiable.abstract'
|
2019-03-04 13:05:27 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Agreements Conditions submodule of Ocean Protocol.
|
|
|
|
*/
|
2019-03-21 02:56:58 +01:00
|
|
|
export class OceanAgreementsConditions extends Instantiable {
|
2019-03-04 13:05:27 +01:00
|
|
|
/**
|
|
|
|
* Returns the instance of OceanAgreementsConditions.
|
|
|
|
* @return {Promise<OceanAgreementsConditions>}
|
|
|
|
*/
|
2019-11-15 00:00:10 +01:00
|
|
|
public static async getInstance(
|
|
|
|
config: InstantiableConfig
|
|
|
|
): Promise<OceanAgreementsConditions> {
|
2019-03-21 02:56:58 +01:00
|
|
|
const instance = new OceanAgreementsConditions()
|
|
|
|
instance.setInstanceConfig(config)
|
2019-03-04 13:05:27 +01:00
|
|
|
|
2019-03-21 02:56:58 +01:00
|
|
|
return instance
|
2019-03-04 13:05:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Transfers tokens to the EscrowRewardCondition contract as an escrow payment.
|
|
|
|
* This is required before access can be given to the asset data.
|
|
|
|
* @param {string} agreementId Agreement ID.
|
|
|
|
* @param {number} amount Asset amount.
|
|
|
|
* @param {Account} from Account of sender.
|
|
|
|
*/
|
2019-11-15 00:00:10 +01:00
|
|
|
public async lockReward(
|
|
|
|
agreementId: string,
|
|
|
|
amount: number | string,
|
|
|
|
from?: Account
|
|
|
|
) {
|
2019-09-09 12:18:54 +02:00
|
|
|
const { lockRewardCondition, escrowReward } = this.ocean.keeper.conditions
|
2019-03-04 13:05:27 +01:00
|
|
|
|
2019-07-09 11:39:22 +02:00
|
|
|
try {
|
2019-11-15 00:00:10 +01:00
|
|
|
await this.ocean.keeper.token.approve(
|
|
|
|
lockRewardCondition.getAddress(),
|
|
|
|
amount,
|
|
|
|
from.getId()
|
|
|
|
)
|
2019-03-04 13:05:27 +01:00
|
|
|
|
2019-07-09 11:39:22 +02:00
|
|
|
const receipt = await lockRewardCondition.fulfill(
|
|
|
|
agreementId,
|
|
|
|
escrowReward.getAddress(),
|
|
|
|
amount,
|
|
|
|
from && from.getId()
|
|
|
|
)
|
|
|
|
|
|
|
|
return !!receipt.events.Fulfilled
|
|
|
|
} catch {
|
|
|
|
return false
|
|
|
|
}
|
2019-03-04 13:05:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Authorize the consumer defined in the agreement to access (consume) this asset.
|
|
|
|
* @param {string} agreementId Agreement ID.
|
|
|
|
* @param {string} did Asset ID.
|
|
|
|
* @param {string} grantee Consumer address.
|
|
|
|
* @param {Account} from Account of sender.
|
|
|
|
*/
|
2019-11-15 00:00:10 +01:00
|
|
|
public async grantAccess(
|
|
|
|
agreementId: string,
|
|
|
|
did: string,
|
|
|
|
grantee: string,
|
|
|
|
from?: Account
|
|
|
|
) {
|
2019-07-09 11:39:22 +02:00
|
|
|
try {
|
|
|
|
const { accessSecretStoreCondition } = this.ocean.keeper.conditions
|
2019-03-04 13:05:27 +01:00
|
|
|
|
2019-11-15 00:00:10 +01:00
|
|
|
const receipt = await accessSecretStoreCondition.fulfill(
|
|
|
|
agreementId,
|
|
|
|
did,
|
|
|
|
grantee,
|
|
|
|
from && from.getId()
|
|
|
|
)
|
2019-09-05 13:32:56 +02:00
|
|
|
return !!receipt.events.Fulfilled
|
|
|
|
} catch {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Authorize the consumer defined in the agreement to execute a remote service associated with this asset.
|
|
|
|
* @param {string} agreementId Agreement ID.
|
|
|
|
* @param {string} did Asset ID.
|
|
|
|
* @param {string} grantee Consumer address.
|
|
|
|
* @param {Account} from Account of sender.
|
|
|
|
*/
|
2019-11-15 00:00:10 +01:00
|
|
|
public async grantServiceExecution(
|
|
|
|
agreementId: string,
|
|
|
|
did: string,
|
|
|
|
grantee: string,
|
|
|
|
from?: Account
|
|
|
|
) {
|
2019-09-05 13:32:56 +02:00
|
|
|
try {
|
|
|
|
const { computeExecutionCondition } = this.ocean.keeper.conditions
|
|
|
|
|
2019-11-15 00:00:10 +01:00
|
|
|
const receipt = await computeExecutionCondition.fulfill(
|
|
|
|
agreementId,
|
|
|
|
did,
|
|
|
|
grantee,
|
|
|
|
from && from.getId()
|
|
|
|
)
|
2019-07-09 11:39:22 +02:00
|
|
|
return !!receipt.events.Fulfilled
|
|
|
|
} catch {
|
|
|
|
return false
|
|
|
|
}
|
2019-03-04 13:05:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Transfer the escrow or locked tokens from the LockRewardCondition contract to the publisher's account.
|
|
|
|
* This should be allowed after access has been given to the consumer and the asset data is downloaded.
|
|
|
|
*
|
|
|
|
* If the AccessSecretStoreCondition already timed out, this function will do a refund by transferring
|
|
|
|
* the token amount to the original consumer.
|
|
|
|
* @param {string} agreementId Agreement ID.
|
|
|
|
* @param {number} amount Asset amount.
|
|
|
|
* @param {string} did Asset ID.
|
|
|
|
* @param {string} consumer Consumer address.
|
|
|
|
* @param {string} publisher Publisher address.
|
|
|
|
* @param {Account} from Account of sender.
|
|
|
|
*/
|
|
|
|
public async releaseReward(
|
|
|
|
agreementId: string,
|
|
|
|
amount: number,
|
|
|
|
did: string,
|
|
|
|
consumer: string,
|
|
|
|
publisher: string,
|
2019-06-20 00:20:09 +02:00
|
|
|
from?: Account
|
2019-03-04 13:05:27 +01:00
|
|
|
) {
|
2019-07-09 11:39:22 +02:00
|
|
|
try {
|
2019-11-15 00:00:10 +01:00
|
|
|
const {
|
|
|
|
escrowReward,
|
|
|
|
accessSecretStoreCondition,
|
|
|
|
lockRewardCondition
|
|
|
|
} = this.ocean.keeper.conditions
|
2019-03-04 13:05:27 +01:00
|
|
|
|
2019-11-15 00:00:10 +01:00
|
|
|
const conditionIdAccess = await accessSecretStoreCondition.generateIdHash(
|
|
|
|
agreementId,
|
|
|
|
did,
|
|
|
|
consumer
|
|
|
|
)
|
2019-07-09 11:39:22 +02:00
|
|
|
const conditionIdLock = await lockRewardCondition.generateIdHash(
|
|
|
|
agreementId,
|
|
|
|
escrowReward.getAddress(),
|
|
|
|
amount
|
|
|
|
)
|
2019-03-04 13:05:27 +01:00
|
|
|
|
2019-07-09 11:39:22 +02:00
|
|
|
const receipt = await escrowReward.fulfill(
|
|
|
|
agreementId,
|
|
|
|
amount,
|
|
|
|
publisher,
|
|
|
|
consumer,
|
|
|
|
conditionIdLock,
|
|
|
|
conditionIdAccess,
|
|
|
|
from && from.getId()
|
|
|
|
)
|
|
|
|
return !!receipt.events.Fulfilled
|
|
|
|
} catch {
|
|
|
|
return false
|
|
|
|
}
|
2019-03-04 13:05:27 +01:00
|
|
|
}
|
|
|
|
}
|