import { loadLightning } from './lightning' import {sequelize, models} from '../models' import { exec } from 'child_process' import * as QRCode from 'qrcode' import * as publicIp from 'public-ip' import password from '../utils/password' import {checkTag, checkCommitHash} from '../utils/gitinfo' const USER_VERSION = 2 const setupDatabase = async () => { console.log('=> [db] starting setup...') await setVersion() try { await sequelize.sync() console.log("=> [db] done syncing") } catch(e) { console.log("db sync failed",e) } await migrate() setupOwnerContact() console.log('=> [db] setup done') } async function setVersion(){ try { await sequelize.query(`PRAGMA user_version = ${USER_VERSION}`) } catch(e) { console.log('=> setVersion failed',e) } } async function migrate(){ addTableColumn('sphinx_chats', 'group_key') addTableColumn('sphinx_chats', 'group_private_key') addTableColumn('sphinx_chats', 'host') try{ await sequelize.query(` CREATE TABLE sphinx_chat_members ( chat_id INT, contact_id INT, role INT, total_spent INT, total_messages INT, last_active DATETIME )`) } catch(e){} } async function addTableColumn(table:string, column:string, type='TEXT') { try { await sequelize.query(`alter table ${table} add ${column} ${type}`) } catch(e) { //console.log('=> migrate failed',e) } } const setupOwnerContact = async () => { const owner = await models.Contact.findOne({ where: { isOwner: true }}) if (!owner) { const lightning = await loadLightning() lightning.getInfo({}, async (err, info) => { if (err) { console.log('[db] error creating node owner due to lnd failure', err) } else { try { const one = await models.Contact.findOne({ where: { id: 1 }}) if(!one){ const contact = await models.Contact.create({ id: 1, publicKey: info.identity_pubkey, isOwner: true, authToken: null }) console.log('[db] created node owner contact, id:', contact.id) } } catch(error) { console.log('[db] error creating owner contact', error) } } }) } } const runMigrations = async () => { await new Promise((resolve, reject) => { const migrate: any = exec('node_modules/.bin/sequelize db:migrate', {env: process.env}, (err, stdout, stderr) => { if (err) { reject(err); } else { resolve(); } } ); // Forward stdout+stderr to this process migrate.stdout.pipe(process.stdout); migrate.stderr.pipe(process.stderr); }); } export { setupDatabase, setupOwnerContact, runMigrations, setupDone } async function setupDone(){ await printGitInfo() printQR() } async function printGitInfo(){ const commitHash = await checkCommitHash() const tag = await checkTag() console.log(`=> Relay version: ${tag}, commit: ${commitHash}`) } async function printQR(){ const ip = process.env.NODE_IP let public_ip if(!ip) { try { public_ip = await publicIp.v4() } catch(e){ console.log(e) } } else { public_ip = ip } if(!public_ip) { console.log('=> no public IP provided') return } let theIP = public_ip // if(!theIP.includes(":")) theIP = public_ip+':3001' const b64 = Buffer.from(`ip::${theIP}::${password||''}`).toString('base64') console.log('Scan this QR in Sphinx app:') console.log(b64) QRCode.toString(b64,{type:'terminal'}, function (err, url) { console.log(url) }) }