misskey/src/remote/activitypub/request.ts

48 lines
1.1 KiB
TypeScript
Raw Normal View History

2018-04-02 20:16:13 +09:00
import { request } from 'https';
2018-06-18 09:54:53 +09:00
const { sign } = require('http-signature');
2018-04-02 20:16:13 +09:00
import { URL } from 'url';
2018-04-05 18:43:06 +09:00
import * as debug from 'debug';
2018-04-10 02:12:17 +09:00
import config from '../../config';
import { ILocalUser } from '../../models/user';
2018-04-02 20:16:13 +09:00
2018-04-05 18:43:06 +09:00
const log = debug('misskey:activitypub:deliver');
2018-06-18 09:54:53 +09:00
export default (user: ILocalUser, url: string, object: any) => new Promise((resolve, reject) => {
2018-04-05 18:43:06 +09:00
log(`--> ${url}`);
2018-04-02 20:16:13 +09:00
const { protocol, hostname, port, pathname, search } = new URL(url);
const req = request({
protocol,
hostname,
port,
method: 'POST',
path: pathname + search,
headers: {
'Content-Type': 'application/activity+json'
}
2018-04-02 20:16:13 +09:00
}, res => {
2018-08-02 15:35:22 +09:00
log(`${url} --> ${res.statusCode}`);
if (res.statusCode >= 400) {
reject();
} else {
resolve();
}
2018-04-02 20:16:13 +09:00
});
sign(req, {
authorizationHeaderName: 'Signature',
2018-04-08 03:58:11 +09:00
key: user.keypair,
2018-08-25 12:46:06 +09:00
keyId: `${config.url}/users/${user._id}/publickey`
2018-04-02 20:16:13 +09:00
});
// Signature: Signature ... => Signature: ...
let sig = req.getHeader('Signature').toString();
sig = sig.replace(/^Signature /, '');
req.setHeader('Signature', sig);
2018-04-02 20:16:13 +09:00
req.end(JSON.stringify(object));
});