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.
 
 
 

242 lines
9.4 KiB

"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
const models_1 = require("./models");
const md5 = require("md5");
const lightning_1 = require("./utils/lightning");
const msg_1 = require("./utils/msg");
const constants = require('../config/constants.json');
const findOrCreateChat = (params) => __awaiter(void 0, void 0, void 0, function* () {
const { chat_id, owner_id, recipient_id } = params;
let chat;
let date = new Date();
date.setMilliseconds(0);
if (chat_id) {
chat = yield models_1.models.Chat.findOne({ where: { id: chat_id } });
// console.log('findOrCreateChat: chat_id exists')
}
else {
console.log("chat does not exists, create new");
const owner = yield models_1.models.Contact.findOne({ where: { id: owner_id } });
const recipient = yield models_1.models.Contact.findOne({ where: { id: recipient_id } });
const uuid = md5([owner.publicKey, recipient.publicKey].sort().join("-"));
// find by uuid
chat = yield models_1.models.Chat.findOne({ where: { uuid } });
if (!chat) { // no chat! create new
chat = yield models_1.models.Chat.create({
uuid: uuid,
contactIds: JSON.stringify([parseInt(owner_id), parseInt(recipient_id)]),
createdAt: date,
updatedAt: date,
type: constants.chat_types.conversation
});
}
}
return chat;
});
exports.findOrCreateChat = findOrCreateChat;
const sendContactKeys = (args) => __awaiter(void 0, void 0, void 0, function* () {
const { type, contactIds, contactPubKey, sender, success, failure } = args;
const msg = newkeyexchangemsg(type, sender);
let yes = null;
let no = null;
let cids = contactIds;
if (!contactIds)
cids = [null]; // nully
yield asyncForEach(cids, (contactId) => __awaiter(void 0, void 0, void 0, function* () {
let destination_key;
if (!contactId) { // nully
destination_key = contactPubKey;
}
else {
if (contactId == sender.id) {
return;
}
const contact = yield models_1.models.Contact.findOne({ where: { id: contactId } });
destination_key = contact.publicKey;
}
performKeysendMessage({
destination_key,
amount: 3,
msg: JSON.stringify(msg),
success: (data) => {
yes = data;
},
failure: (error) => {
no = error;
}
});
}));
if (no && failure) {
failure(no);
}
if (!no && yes && success) {
success(yes);
}
});
exports.sendContactKeys = sendContactKeys;
const sendMessage = (params) => __awaiter(void 0, void 0, void 0, function* () {
const { type, chat, message, sender, amount, success, failure } = params;
const m = newmsg(type, chat, sender, message);
const contactIds = typeof chat.contactIds === 'string' ? JSON.parse(chat.contactIds) : chat.contactIds;
let yes = null;
let no = null;
console.log('all contactIds', contactIds);
yield asyncForEach(contactIds, (contactId) => __awaiter(void 0, void 0, void 0, function* () {
if (contactId == sender.id) {
return;
}
console.log('-> sending to contact #', contactId);
const contact = yield models_1.models.Contact.findOne({ where: { id: contactId } });
const destkey = contact.publicKey;
const finalMsg = yield msg_1.personalizeMessage(m, contactId, destkey);
const opts = {
dest: destkey,
data: JSON.stringify(finalMsg),
amt: amount || 3,
};
try {
const r = yield lightning_1.keysendMessage(opts);
yes = r;
}
catch (e) {
console.log("KEYSEND ERROR", e);
no = e;
}
}));
if (yes) {
if (success)
success(yes);
}
else {
if (failure)
failure(no);
}
});
exports.sendMessage = sendMessage;
const performKeysendMessage = ({ destination_key, amount, msg, success, failure }) => __awaiter(void 0, void 0, void 0, function* () {
const opts = {
dest: destination_key,
data: msg || JSON.stringify({}),
amt: Math.max(amount, 3)
};
try {
const r = yield lightning_1.keysendMessage(opts);
console.log("=> external keysend");
if (success)
success(r);
}
catch (e) {
console.log("MESSAGE ERROR", e);
if (failure)
failure(e);
}
});
exports.performKeysendMessage = performKeysendMessage;
function findOrCreateContactByPubkey(senderPubKey) {
return __awaiter(this, void 0, void 0, function* () {
let sender = yield models_1.models.Contact.findOne({ where: { publicKey: senderPubKey } });
if (!sender) {
sender = yield models_1.models.Contact.create({
publicKey: senderPubKey,
alias: "Unknown",
status: 1
});
const owner = yield models_1.models.Contact.findOne({ where: { isOwner: true } });
sendContactKeys({
contactIds: [sender.id],
sender: owner,
type: constants.message_types.contact_key,
});
}
return sender;
});
}
exports.findOrCreateContactByPubkey = findOrCreateContactByPubkey;
function findOrCreateChatByUUID(chat_uuid, contactIds) {
return __awaiter(this, void 0, void 0, function* () {
let chat = yield models_1.models.Chat.findOne({ where: { uuid: chat_uuid } });
if (!chat) {
var date = new Date();
date.setMilliseconds(0);
chat = yield models_1.models.Chat.create({
uuid: chat_uuid,
contactIds: JSON.stringify(contactIds || []),
createdAt: date,
updatedAt: date,
type: 0 // conversation
});
}
return chat;
});
}
exports.findOrCreateChatByUUID = findOrCreateChatByUUID;
function sleep(ms) {
return __awaiter(this, void 0, void 0, function* () {
return new Promise(resolve => setTimeout(resolve, ms));
});
}
exports.sleep = sleep;
function parseReceiveParams(payload) {
return __awaiter(this, void 0, void 0, function* () {
const dat = payload.content || payload;
const sender_pub_key = dat.sender.pub_key;
const chat_uuid = dat.chat.uuid;
const chat_type = dat.chat.type;
const chat_members = dat.chat.members || {};
const chat_name = dat.chat.name;
const chat_key = dat.chat.groupKey;
const chat_host = dat.chat.host;
const amount = dat.message.amount;
const content = dat.message.content;
const mediaToken = dat.message.mediaToken;
const msg_id = dat.message.id || 0;
const mediaKey = dat.message.mediaKey;
const mediaType = dat.message.mediaType;
const isConversation = chat_type && chat_type == constants.chat_types.group;
let sender;
let chat;
const owner = yield models_1.models.Contact.findOne({ where: { isOwner: true } });
if (isConversation) {
sender = yield findOrCreateContactByPubkey(sender_pub_key);
chat = yield findOrCreateChatByUUID(chat_uuid, [parseInt(owner.id), parseInt(sender.id)]);
}
else { // group
sender = yield models_1.models.Contact.findOne({ where: { publicKey: sender_pub_key } });
chat = yield models_1.models.Chat.findOne({ where: { uuid: chat_uuid } });
}
return { owner, sender, chat, sender_pub_key, chat_uuid, amount, content, mediaToken, mediaKey, mediaType, chat_type, msg_id, chat_members, chat_name, chat_host, chat_key };
});
}
exports.parseReceiveParams = parseReceiveParams;
function asyncForEach(array, callback) {
return __awaiter(this, void 0, void 0, function* () {
for (let index = 0; index < array.length; index++) {
yield callback(array[index], index, array);
}
});
}
function newmsg(type, chat, sender, message) {
return {
type: type,
chat: Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ uuid: chat.uuid }, chat.name && { name: chat.name }), chat.type && { type: chat.type }), chat.members && { members: chat.members }), chat.groupKey && { groupKey: chat.groupKey }), chat.host && { host: chat.host }),
message: message,
};
}
function newkeyexchangemsg(type, sender) {
return {
type: type,
sender: Object.assign({
// pub_key: sender.publicKey,
contact_key: sender.contactKey }, sender.alias && { alias: sender.alias })
};
}
//# sourceMappingURL=helpers.js.map