You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
70 lines
2.1 KiB
70 lines
2.1 KiB
import * as path from 'path'
|
|
import RNCryptor from '../utils/rncryptor'
|
|
import * as fetch from 'node-fetch'
|
|
import {parseLDAT} from '../utils/ldat'
|
|
import * as rsa from '../crypto/rsa'
|
|
import * as crypto from 'crypto'
|
|
import * as Blob from 'fetch-blob'
|
|
|
|
const constants = require(path.join(__dirname,'../../config/constants.json'))
|
|
const msgtypes = constants.message_types
|
|
|
|
export async function modifyPayload(payload, chat) {
|
|
if(payload.type===msgtypes.attachment) {
|
|
console.log("MODIFY, ", payload)
|
|
|
|
const mt = payload.message && payload.message.mediaToken
|
|
const key = payload.message && payload.message.mediaKey
|
|
const typ = payload.message && payload.message.mediaType
|
|
if(!mt || !key) return payload
|
|
|
|
const terms = parseLDAT(mt)
|
|
if(!terms.host) return payload
|
|
|
|
try {
|
|
const r = await fetch(`https://${terms.host}/file/${mt}`)
|
|
const buf = await r.buffer()
|
|
|
|
const decMediaKey = rsa.decrypt(chat.groupPrivateKey, key)
|
|
|
|
const imgBase64 = RNCryptor.Decrypt(decMediaKey, buf.toString('base64'))
|
|
|
|
const newKey = crypto.randomBytes(20).toString('hex')
|
|
|
|
const encImg = RNCryptor.Encrypt(newKey, imgBase64)
|
|
|
|
const resp = await fetch(`https://${terms.host}/file`, {
|
|
method: 'POST',
|
|
body: new Blob([encImg], { type: typ||'image/jpg', name:'file', filename:'Image.jpg' })
|
|
})
|
|
|
|
let json = resp.json()
|
|
if(!json.muid) return payload
|
|
|
|
// PUT NEW TERMS, to finish in personalizeMessage
|
|
const amt = terms.meta&&terms.meta.amt
|
|
const ttl = terms.meta&&terms.meta.ttl
|
|
const mediaTerms: {[k:string]:any} = {
|
|
muid:json.muid, ttl:ttl||31536000,
|
|
meta:{...amt && {amt}},
|
|
skipSigning: amt ? true : false // only sign if its free
|
|
}
|
|
|
|
const encKey = rsa.encrypt(chat.groupKey, newKey)
|
|
return fillmsg(payload, {mediaTerms,mediaKey:encKey}) // key is re-encrypted later
|
|
} catch(e) {
|
|
return payload
|
|
}
|
|
// how to link w og msg? ogMediaToken?
|
|
}
|
|
return payload
|
|
}
|
|
|
|
function fillmsg(full, props){
|
|
return {
|
|
...full, message: {
|
|
...full.message,
|
|
...props,
|
|
}
|
|
}
|
|
}
|