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 meme from '../utils/meme' import * as FormData from 'form-data' 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) console.log("[modify] terms", terms) if(!terms.host) return payload try { console.log(`Bearer ${meme.mediaToken}`) const r = await fetch(`https://${terms.host}/file/${mt}`, { headers: {'Authorization': `Bearer ${meme.mediaToken}`} }) const buf = await r.buffer() console.log("[modify] buf.length", buf.length) // "Unauthorized" const decMediaKey = rsa.decrypt(chat.groupPrivateKey, key) console.log("[modify] decMediaKey", decMediaKey) const imgBase64 = RNCryptor.Decrypt(decMediaKey, buf.toString('base64')) console.log("[modify] imgBase64.length", imgBase64.length) const newKey = crypto.randomBytes(20).toString('hex') const encImg = RNCryptor.Encrypt(newKey, imgBase64) console.log("[modify] encImg.length", encImg.length) var encImgBuffer = Buffer.from(encImg,'base64'); console.log("[modify] encImgBuffer.length", encImgBuffer.length) const bod = new FormData() bod.append('file', encImgBuffer, { contentType: typ||'image/jpg', filename: 'Image.jpg', }) const resp = await fetch(`https://${terms.host}/file`, { method: 'POST', headers: { 'Authorization': `Bearer ${meme.mediaToken}`, 'Content-Type': 'multipart/form-data' }, body:bod }) let json = await resp.json() console.log("[modify] post json", 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 } console.log("[modify] new terms", mediaTerms) const encKey = rsa.encrypt(chat.groupKey, newKey) console.log("[modify] new encKey", encKey) return fillmsg(payload, {mediaTerms,mediaKey:encKey}) // key is re-encrypted later } catch(e) { console.log("[modify] error", e) return payload } // how to link w og msg? ogMediaToken? } else { return payload } } function fillmsg(full, props){ return { ...full, message: { ...full.message, ...props, } } }