1
0
mirror of https://github.com/oceanprotocol-archive/squid-js.git synced 2024-02-02 15:31:51 +01:00

init for add proof

This commit is contained in:
Bill Barman 2018-11-20 17:44:25 +08:00
parent 72e09f3c22
commit d692bd8cda

View File

@ -48,6 +48,15 @@ export default class DDO {
return false return false
} }
public static signText(text: string, keyValue: string, authenticationType: string): string {
var signature = ""
if ( authenticationType === Authentication.TYPE_RSA ) {
var key = ursa.createPrivateKey(keyValue, "", "utf8")
signature = key.hashAndSign("SHA256", text, "utf8", "utf8")
}
return signature
}
public context: string = DDO.CONTEXT public context: string = DDO.CONTEXT
public did: string public did: string
public created: string public created: string
@ -154,12 +163,19 @@ export default class DDO {
keyType = PublicKey.PEM keyType = PublicKey.PEM
} }
if (keyType === PublicKey.PEM ) { if (keyType === PublicKey.PEM ) {
// generate the key pairs
const keys = ursa.generatePrivateKey(1024, 65537) const keys = ursa.generatePrivateKey(1024, 65537)
// add a public key record
const nextIndex = this.publicKeys.length + 1 const nextIndex = this.publicKeys.length + 1
const keyId = (this.did ? this.did : "" ) + "#keys=" + nextIndex const keyId = (this.did ? this.did : "" ) + "#keys=" + nextIndex
const publicKey = new PublicKey({id: keyId, owner: keyId, type: keyType}) const publicKey = new PublicKey({id: keyId, owner: keyId, type: keyType})
publicKey.value = keys.toPublicPem("utf8") publicKey.value = keys.toPublicPem("utf8")
this.publicKeys.push(publicKey) this.publicKeys.push(publicKey)
// add an authentication record
const authentication = new Authentication({ publicKey: publicKey.id, type: publicKey.type})
this.authentications.push(authentication)
return keys.toPrivatePem("utf8") return keys.toPrivatePem("utf8")
} }
return null return null
@ -174,6 +190,29 @@ export default class DDO {
return service return service
} }
public addProof(authIndex, privateKey, signatureText) {
if ( authIndex == null ) {
authIndex = 0
}
const authentication = this.authentications[authIndex]
// get the public key stored for this authentication
const publicKey = this.getPublicKey(authentication.publicKeyId)
if ( signatureText == null ) {
signatureText = this.hashTextList().join()
}
const signature = DDO.signText(signatureText, privateKey, publicKey.type)
const signatureBuffer = new Buffer(signature, 'ascii')
const date = new Date()
this.proof = new Proof({
created: date.toISOString(),
creator: publicKey.id,
type: publicKey.type,
signatureValue: signatureBuffer.toString("base64"),
})
}
public isProofDefined(): boolean { public isProofDefined(): boolean {
return this.proof != null return this.proof != null
} }