2019-03-11 22:52:53 +01:00
|
|
|
import { assert } from "chai"
|
|
|
|
|
|
|
|
import { config } from "../config"
|
|
|
|
|
2019-03-21 03:02:05 +01:00
|
|
|
import { Ocean, Account, DDO } from "../../src" // @oceanprotocol/squid
|
2019-03-11 22:52:53 +01:00
|
|
|
|
|
|
|
// WARN: not integration test. It has been done here because constant values
|
|
|
|
// depends on the first account on spree (only accessible from integration test)
|
|
|
|
describe("Signature", () => {
|
|
|
|
|
2019-03-21 03:02:05 +01:00
|
|
|
let ocean: Ocean
|
2019-03-11 22:52:53 +01:00
|
|
|
let consumer: Account
|
|
|
|
|
|
|
|
before(async () => {
|
2019-04-01 12:40:45 +02:00
|
|
|
ocean = await Ocean.getInstance(config)
|
2019-03-11 22:52:53 +01:00
|
|
|
|
|
|
|
// Accounts
|
2019-04-01 12:40:45 +02:00
|
|
|
consumer = (await ocean.accounts.list())[0]
|
2019-03-11 22:52:53 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
it("should generate the correct signature", async () => {
|
|
|
|
const templateId = `0x${"f".repeat(40)}`
|
|
|
|
const agreementId = `0x${"e".repeat(64)}`
|
|
|
|
|
|
|
|
const accessId = `0x${"a".repeat(64)}`
|
|
|
|
const lockId = `0x${"b".repeat(64)}`
|
|
|
|
const escrowId = `0x${"c".repeat(64)}`
|
|
|
|
|
2019-03-28 12:20:22 +01:00
|
|
|
const hash = await ocean.utils.agreements.hashServiceAgreement(
|
2019-03-11 22:52:53 +01:00
|
|
|
templateId,
|
|
|
|
agreementId,
|
|
|
|
[accessId, lockId, escrowId],
|
|
|
|
[0, 0, 0],
|
|
|
|
[0, 0, 0],
|
|
|
|
)
|
|
|
|
|
|
|
|
assert.equal(hash, "0x67901517c18a3d23e05806fff7f04235cc8ae3b1f82345b8bfb3e4b02b5800c7", "The signatuere is not correct.")
|
|
|
|
})
|
|
|
|
|
|
|
|
it("should generate the correct signature", async () => {
|
2019-03-21 03:02:05 +01:00
|
|
|
const templates = ocean.keeper.templates
|
2019-03-11 22:52:53 +01:00
|
|
|
|
|
|
|
const did = `did:op:${"c".repeat(64)}`
|
|
|
|
const templateId = `0x${"f".repeat(40)}`
|
|
|
|
const agreementId = `0x${"e".repeat(64)}`
|
|
|
|
const serviceDefinitionId = "0"
|
|
|
|
|
|
|
|
const serviceAgreementTemplate = await templates.escrowAccessSecretStoreTemplate.getServiceAgreementTemplate()
|
|
|
|
|
|
|
|
const ddo = new DDO({
|
|
|
|
id: did,
|
|
|
|
service: [
|
|
|
|
{
|
|
|
|
type: "Access",
|
|
|
|
purchaseEndpoint: undefined,
|
|
|
|
serviceEndpoint: undefined,
|
|
|
|
serviceDefinitionId,
|
|
|
|
templateId,
|
|
|
|
serviceAgreementTemplate,
|
|
|
|
} as any,
|
2019-03-14 16:57:28 +01:00
|
|
|
{
|
|
|
|
type: "Metadata",
|
|
|
|
metadata: {
|
|
|
|
base: {
|
|
|
|
price: 10,
|
2019-03-14 21:28:51 +01:00
|
|
|
},
|
|
|
|
},
|
2019-03-14 16:57:28 +01:00
|
|
|
} as any,
|
2019-03-11 22:52:53 +01:00
|
|
|
],
|
|
|
|
})
|
|
|
|
|
2019-03-28 12:20:22 +01:00
|
|
|
const signature = await ocean.utils.agreements.signServiceAgreement(
|
2019-03-11 22:52:53 +01:00
|
|
|
ddo,
|
|
|
|
serviceDefinitionId,
|
|
|
|
agreementId,
|
2019-03-25 13:47:21 +01:00
|
|
|
[`0x${"1".repeat(64)}`, `0x${"2".repeat(64)}`, `0x${"3".repeat(64)}`],
|
2019-03-11 22:52:53 +01:00
|
|
|
consumer,
|
|
|
|
)
|
|
|
|
|
|
|
|
assert.equal(
|
|
|
|
signature,
|
|
|
|
// tslint:disable-next-line
|
2019-04-01 12:40:45 +02:00
|
|
|
"0x3aa8a1c48b8e582d694bbd4ba3a29fde573b78da9720dc48baeb831b2163e1fa6e10e983882ebf8a00f4124de2505136354fd146934053f0d58bba4eced5f8d000",
|
2019-03-11 22:52:53 +01:00
|
|
|
"The signatuere is not correct.",
|
|
|
|
)
|
|
|
|
})
|
|
|
|
})
|