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.

212 lines
5.3 KiB

5 years ago
import {models} from '../models'
import { sendNotification } from '../hub'
import * as socket from '../utils/socket'
import * as jsonUtils from '../utils/json'
import * as helpers from '../helpers'
import { success } from '../utils/res'
import * as lightning from '../utils/lightning'
import {tokenFromTerms} from '../utils/ldat'
import * as constants from '../../config/constants.json'
5 years ago
const sendPayment = async (req, res) => {
5 years ago
const {
5 years ago
amount,
chat_id,
contact_id,
destination_key,
media_type,
muid,
text,
remote_text,
dimensions,
5 years ago
remote_text_map,
contact_ids,
5 years ago
} = req.body
console.log('[send payment]', req.body)
if (destination_key && !contact_id && !chat_id) {
return helpers.performKeysendMessage({
destination_key,
amount,
msg:'{}',
success: () => {
console.log('payment sent!')
success(res, {destination_key, amount})
},
failure: (error) => {
res.status(200);
res.json({ success: false, error });
res.end();
}
})
}
const owner = await models.Contact.findOne({ where: { isOwner: true }})
const chat = await helpers.findOrCreateChat({
chat_id,
owner_id: owner.id,
recipient_id: contact_id
})
var date = new Date();
date.setMilliseconds(0)
const msg: {[k:string]:any} = {
chatId: chat.id,
sender: owner.id,
type: constants.message_types.direct_payment,
amount: amount,
amountMsat: parseFloat(amount) * 1000,
date: date,
createdAt: date,
updatedAt: date
}
if(text) msg.messageContent = text
if(remote_text) msg.remoteMessageContent = remote_text
if(muid){
const myMediaToken = await tokenFromTerms({
meta:{dim:dimensions}, host:'',
muid, ttl:null, // default one year
pubkey: owner.publicKey
})
msg.mediaToken = myMediaToken
msg.mediaType = media_type || ''
}
const message = await models.Message.create(msg)
const msgToSend: {[k:string]:any} = {
id:message.id,
amount,
}
if(muid) {
msgToSend.mediaType = media_type||'image/jpeg'
msgToSend.mediaTerms = {muid,meta:{dim:dimensions}}
}
if(remote_text) msgToSend.content = remote_text
5 years ago
// if contact_ids, replace that in "chat" below
// if remote text map, put that in
let theChat = chat
if(contact_ids){
theChat = {...chat.dataValues, contactIds:contact_ids}
if(remote_text_map) msgToSend.content = remote_text_map
}
5 years ago
helpers.sendMessage({
5 years ago
chat: theChat,
5 years ago
sender: owner,
type: constants.message_types.direct_payment,
message: msgToSend,
amount: amount,
success: async (data) => {
// console.log('payment sent', { data })
success(res, jsonUtils.messageToJson(message, chat))
},
failure: async (error) => {
await message.update({status: constants.statuses.failed})
5 years ago
res.status(200);
res.json({
success: false,
message: jsonUtils.messageToJson(message, chat)
});
5 years ago
res.end();
}
})
};
const receivePayment = async (payload) => {
console.log('received payment', { payload })
var date = new Date();
date.setMilliseconds(0)
const {owner, sender, chat, amount, content, mediaType, mediaToken} = await helpers.parseReceiveParams(payload)
if(!owner || !sender || !chat) {
return console.log('=> no group chat!')
}
const msg: {[k:string]:any} = {
chatId: chat.id,
type: constants.message_types.direct_payment,
sender: sender.id,
amount: amount,
amountMsat: parseFloat(amount) * 1000,
date: date,
createdAt: date,
updatedAt: date
}
if(content) msg.messageContent = content
if(mediaType) msg.mediaType = mediaType
if(mediaToken) msg.mediaToken = mediaToken
const message = await models.Message.create(msg)
console.log('saved message', message.dataValues)
socket.sendJson({
type: 'direct_payment',
5 years ago
response: jsonUtils.messageToJson(message, chat, sender)
5 years ago
})
sendNotification(chat, sender.alias, 'message')
}
const listPayments = async (req, res) => {
const limit = (req.query.limit && parseInt(req.query.limit)) || 100
const offset = (req.query.offset && parseInt(req.query.offset)) || 0
const payments: any[] = []
const response:any = await lightning.listInvoices()
const invs = response && response.invoices
if(invs && invs.length){
invs.forEach(inv=>{
const val = inv.value && parseInt(inv.value)
if(val && val>1) {
let payment_hash=''
if(inv.r_hash){
payment_hash = Buffer.from(inv.r_hash).toString('hex')
}
payments.push({
type:'invoice',
amount:parseInt(inv.value),
date:parseInt(inv.creation_date),
payment_request:inv.payment_request,
payment_hash
})
}
})
}
const res2:any = await lightning.listPayments()
const pays = res2 && res2.payments
if(pays && pays.length){
pays.forEach(pay=>{
const val = pay.value && parseInt(pay.value)
if(val && val>1) {
payments.push({
type:'payment',
amount:parseInt(pay.value),
date:parseInt(pay.creation_date),
pubkey:pay.path[pay.path.length-1],
payment_hash: pay.payment_hash,
})
}
})
}
// latest one first
payments.sort((a,b)=> b.date - a.date)
success(res, payments.splice(offset, limit))
};
export {
sendPayment,
receivePayment,
listPayments,
}