2019-06-20 00:20:09 +02:00
|
|
|
import { assert } from 'chai'
|
2019-03-11 22:52:53 +01:00
|
|
|
|
2019-06-20 00:20:09 +02:00
|
|
|
import { config } from '../config'
|
2019-03-11 22:52:53 +01:00
|
|
|
|
2019-06-20 00:20:09 +02: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)
|
2019-06-20 00:20:09 +02:00
|
|
|
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-06-24 13:06:38 +02:00
|
|
|
;[consumer] = await ocean.accounts.list()
|
2019-03-11 22:52:53 +01:00
|
|
|
})
|
|
|
|
|
2019-06-20 00:20:09 +02:00
|
|
|
it('should generate the correct signature', async () => {
|
|
|
|
const templateId = `0x${'f'.repeat(40)}`
|
|
|
|
const agreementId = `0x${'e'.repeat(64)}`
|
2019-03-11 22:52:53 +01:00
|
|
|
|
2019-06-20 00:20:09 +02:00
|
|
|
const accessId = `0x${'a'.repeat(64)}`
|
|
|
|
const lockId = `0x${'b'.repeat(64)}`
|
|
|
|
const escrowId = `0x${'c'.repeat(64)}`
|
2019-03-11 22:52:53 +01:00
|
|
|
|
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],
|
2019-06-20 00:20:09 +02:00
|
|
|
[0, 0, 0]
|
2019-03-11 22:52:53 +01:00
|
|
|
)
|
|
|
|
|
2019-06-20 00:20:09 +02:00
|
|
|
assert.equal(
|
|
|
|
hash,
|
|
|
|
'0x67901517c18a3d23e05806fff7f04235cc8ae3b1f82345b8bfb3e4b02b5800c7',
|
|
|
|
'The signatuere is not correct.'
|
|
|
|
)
|
2019-03-11 22:52:53 +01:00
|
|
|
})
|
|
|
|
|
2019-06-20 00:20:09 +02:00
|
|
|
it('should generate the correct signature', async () => {
|
|
|
|
const { templates } = ocean.keeper
|
2019-03-11 22:52:53 +01:00
|
|
|
|
2019-06-20 00:20:09 +02:00
|
|
|
const did = `did:op:${'c'.repeat(64)}`
|
|
|
|
const templateId = `0x${'f'.repeat(40)}`
|
|
|
|
const agreementId = `0x${'e'.repeat(64)}`
|
|
|
|
const serviceDefinitionId = '0'
|
2019-03-11 22:52:53 +01:00
|
|
|
|
|
|
|
const serviceAgreementTemplate = await templates.escrowAccessSecretStoreTemplate.getServiceAgreementTemplate()
|
|
|
|
|
|
|
|
const ddo = new DDO({
|
|
|
|
id: did,
|
|
|
|
service: [
|
|
|
|
{
|
2019-06-20 00:20:09 +02:00
|
|
|
type: 'Access',
|
2019-03-11 22:52:53 +01:00
|
|
|
purchaseEndpoint: undefined,
|
|
|
|
serviceEndpoint: undefined,
|
|
|
|
serviceDefinitionId,
|
|
|
|
templateId,
|
2019-06-20 00:20:09 +02:00
|
|
|
serviceAgreementTemplate
|
2019-03-11 22:52:53 +01:00
|
|
|
} as any,
|
2019-03-14 16:57:28 +01:00
|
|
|
{
|
2019-06-20 00:20:09 +02:00
|
|
|
type: 'Metadata',
|
2019-03-14 16:57:28 +01:00
|
|
|
metadata: {
|
|
|
|
base: {
|
2019-06-20 00:20:09 +02:00
|
|
|
price: 10
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} 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-06-20 00:20:09 +02:00
|
|
|
[
|
|
|
|
`0x${'1'.repeat(64)}`,
|
|
|
|
`0x${'2'.repeat(64)}`,
|
|
|
|
`0x${'3'.repeat(64)}`
|
|
|
|
],
|
|
|
|
consumer
|
2019-03-11 22:52:53 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
assert.equal(
|
|
|
|
signature,
|
|
|
|
// tslint:disable-next-line
|
2019-06-20 00:20:09 +02:00
|
|
|
'0x3aa8a1c48b8e582d694bbd4ba3a29fde573b78da9720dc48baeb831b2163e1fa6e10e983882ebf8a00f4124de2505136354fd146934053f0d58bba4eced5f8d000',
|
|
|
|
'The signatuere is not correct.'
|
2019-03-11 22:52:53 +01:00
|
|
|
)
|
|
|
|
})
|
|
|
|
})
|