Fix well known and json parser with mastodon

This commit is contained in:
Chocobozzz 2017-11-29 11:34:44 +01:00
parent 14063e9656
commit 165cdc75bf
No known key found for this signature in database
GPG Key ID: 583A612D890159BE
7 changed files with 25 additions and 5 deletions

View File

@ -76,7 +76,10 @@ app.use(morgan('combined', {
stream: { write: logger.info }
}))
// For body requests
app.use(bodyParser.json({ limit: '500kb' }))
app.use(bodyParser.json({
type: 'application/*+json',
limit: '500kb'
}))
app.use(bodyParser.urlencoded({ extended: false }))
// ----------- Tracker -----------

View File

@ -27,6 +27,7 @@ function webfingerController (req: express.Request, res: express.Response, next:
links: [
{
rel: 'self',
type: 'application/activity+json',
href: account.url
}
]

View File

@ -219,7 +219,11 @@ const VIDEO_MIMETYPE_EXT = {
const SERVER_ACCOUNT_NAME = 'peertube'
const ACTIVITY_PUB = {
ACCEPT_HEADER: 'application/ld+json; profile="https://www.w3.org/ns/activitystreams"',
ACCEPT_HEADERS: [
'application/activity+json, application/ld+json',
'application/ld+json; profile="https://www.w3.org/ns/activitystreams"'
],
ACCEPT_HEADER: '',
PUBLIC: 'https://www.w3.org/ns/activitystreams#Public',
COLLECTION_ITEMS_PER_PAGE: 10,
FETCH_PAGE_LIMIT: 100,
@ -230,6 +234,7 @@ const ACTIVITY_PUB = {
MAGNET: [ 'application/x-bittorrent;x-scheme-handler/magnet' ]
}
}
ACTIVITY_PUB.ACCEPT_HEADER = ACTIVITY_PUB.ACCEPT_HEADERS[0]
// ---------------------------------------------------------------------------

View File

@ -66,6 +66,8 @@ const sequelize = new Sequelize(dbname, username, password, {
operatorsAliases: false,
logging: (message: string, benchmark: number) => {
if (process.env.NODE_DB_LOG === 'false') return
let newMessage = message
if (isTestInstance() === true && benchmark !== undefined) {
newMessage += ' | ' + benchmark + 'ms'

View File

@ -37,10 +37,12 @@ async function checkSignature (req: Request, res: Response, next: NextFunction)
function executeIfActivityPub (fun: RequestHandler | RequestHandler[]) {
return (req: Request, res: Response, next: NextFunction) => {
if (req.header('Accept') !== ACTIVITY_PUB.ACCEPT_HEADER) {
if (ACTIVITY_PUB.ACCEPT_HEADERS.indexOf(req.header('Accept')) === -1) {
return next()
}
logger.debug('ActivityPub request for %s.', req.url)
if (Array.isArray(fun) === true) {
return eachSeries(fun as RequestHandler[], (f, cb) => {
f(req, res, cb)

View File

@ -616,6 +616,13 @@ toActivityPubObject = function (this: VideoInstance) {
})
}
// Add video url too
url.push({
type: 'Link',
mimeType: 'text/html',
url: CONFIG.WEBSERVER.URL + '/videos/watch/' + this.uuid
})
const videoObject: VideoTorrentObject = {
type: 'Video' as 'Video',
id: this.url,

View File

@ -471,9 +471,9 @@ bitcore-lib@^0.13.7:
inherits "=2.0.1"
lodash "=3.10.1"
"bitcore-message@github:comakery/bitcore-message#dist":
"bitcore-message@github:CoMakery/bitcore-message#dist":
version "1.0.2"
resolved "https://codeload.github.com/comakery/bitcore-message/tar.gz/8799cc327029c3d34fc725f05b2cf981363f6ebf"
resolved "https://codeload.github.com/CoMakery/bitcore-message/tar.gz/8799cc327029c3d34fc725f05b2cf981363f6ebf"
dependencies:
bitcore-lib "^0.13.7"