2021-10-16 08:16:24 +00:00
|
|
|
import * as assert from 'assert';
|
2022-11-24 06:39:00 +00:00
|
|
|
import httpSignature from '@peertube/http-signature';
|
2022-09-17 18:27:08 +00:00
|
|
|
import { genRsaKeyPair } from '../../src/misc/gen-key-pair.js';
|
2022-12-04 01:16:03 +00:00
|
|
|
import { createSignedPost, createSignedGet } from '../../src/activitypub/ap-request.js';
|
2021-10-16 08:16:24 +00:00
|
|
|
|
|
|
|
export const buildParsedSignature = (signingString: string, signature: string, algorithm: string) => {
|
|
|
|
return {
|
|
|
|
scheme: 'Signature',
|
|
|
|
params: {
|
|
|
|
keyId: 'KeyID', // dummy, not used for verify
|
|
|
|
algorithm: algorithm,
|
|
|
|
headers: [ '(request-target)', 'date', 'host', 'digest' ], // dummy, not used for verify
|
|
|
|
signature: signature,
|
|
|
|
},
|
|
|
|
signingString: signingString,
|
2022-05-21 13:21:41 +00:00
|
|
|
algorithm: algorithm.toUpperCase(),
|
2021-10-16 08:16:24 +00:00
|
|
|
keyId: 'KeyID', // dummy, not used for verify
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('ap-request', () => {
|
|
|
|
it('createSignedPost with verify', async () => {
|
|
|
|
const keypair = await genRsaKeyPair();
|
|
|
|
const key = { keyId: 'x', 'privateKeyPem': keypair.privateKey };
|
|
|
|
const url = 'https://example.com/inbox';
|
|
|
|
const activity = { a: 1 };
|
|
|
|
const body = JSON.stringify(activity);
|
|
|
|
const headers = {
|
2022-05-21 13:21:41 +00:00
|
|
|
'User-Agent': 'UA',
|
2021-10-16 08:16:24 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
const req = createSignedPost({ key, url, body, additionalHeaders: headers });
|
|
|
|
|
|
|
|
const parsed = buildParsedSignature(req.signingString, req.signature, 'rsa-sha256');
|
|
|
|
|
|
|
|
const result = httpSignature.verifySignature(parsed, keypair.publicKey);
|
|
|
|
assert.deepStrictEqual(result, true);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('createSignedGet with verify', async () => {
|
|
|
|
const keypair = await genRsaKeyPair();
|
|
|
|
const key = { keyId: 'x', 'privateKeyPem': keypair.privateKey };
|
|
|
|
const url = 'https://example.com/outbox';
|
|
|
|
const headers = {
|
2022-05-21 13:21:41 +00:00
|
|
|
'User-Agent': 'UA',
|
2021-10-16 08:16:24 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
const req = createSignedGet({ key, url, additionalHeaders: headers });
|
|
|
|
|
|
|
|
const parsed = buildParsedSignature(req.signingString, req.signature, 'rsa-sha256');
|
|
|
|
|
|
|
|
const result = httpSignature.verifySignature(parsed, keypair.publicKey);
|
|
|
|
assert.deepStrictEqual(result, true);
|
|
|
|
});
|
|
|
|
});
|