Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Synchronous backups #166

Merged
merged 25 commits into from
Oct 4, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
d13a653
chore: wip
Jasonvdb Aug 8, 2023
ead2eeb
Merge branch 'master' into sync-backup
Jasonvdb Aug 21, 2023
3cbb82e
feat: ios remote backup sync
Jasonvdb Aug 22, 2023
32e9a1b
feat: ios backup encryption
Jasonvdb Aug 22, 2023
cd08d8c
feat: fastify server
Jasonvdb Aug 24, 2023
a3fe5fb
wip: slashauth
Jasonvdb Aug 24, 2023
0f9fc53
feat: list backed up files from server, full restore from server
Jasonvdb Aug 31, 2023
135127b
feat: slashauth used in backup server
Jasonvdb Sep 1, 2023
8829635
fix: using slashauth magic link
Jasonvdb Sep 4, 2023
9a5ce5e
wip: sodium
Jasonvdb Sep 6, 2023
71dd44f
feat: android backup encryption
Jasonvdb Sep 13, 2023
98df4c4
feat: android remote backup restore
Jasonvdb Sep 14, 2023
fb7111e
feat: ios signed backup uploads
Jasonvdb Sep 18, 2023
d25c176
Merge branch 'master' into sync-backup
Jasonvdb Sep 20, 2023
901d27b
feat: backup challenge/response for retrieval with node signing
Jasonvdb Sep 20, 2023
c3a9c8c
feat: backup server using storage-abstraction
Jasonvdb Sep 20, 2023
f3494da
feat: server signs client challenge
Jasonvdb Sep 21, 2023
f96e748
feat: ios validating server's signed challenge response
Jasonvdb Sep 22, 2023
467fcba
feat: use ln-verifymessagejs for server message signing
Jasonvdb Sep 25, 2023
9d9de90
feat: ios bearer token auth for restoring backups
Jasonvdb Sep 28, 2023
176497f
feat: android verifying server response on persist
Jasonvdb Sep 29, 2023
d3136e9
feat: android bearer token auth for restoring backups
Jasonvdb Sep 29, 2023
d8fb401
chore: backup documentation
Jasonvdb Oct 2, 2023
e5aa676
fix: clear previously cached bearer token on backup client setup
Jasonvdb Oct 4, 2023
ff9f5d4
Merge branch 'master' into sync-backup
Jasonvdb Oct 4, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
feat: fastify server
  • Loading branch information
Jasonvdb committed Aug 24, 2023
commit cd08d8c1ae77bf1d894a4c7cbdcb130ea57c3e0d
3 changes: 2 additions & 1 deletion backup-server/.gitignore
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
local-storage
local-storage
node_modules
160 changes: 8 additions & 152 deletions backup-server/index.js
Original file line number Diff line number Diff line change
@@ -1,153 +1,9 @@
const http = require('http');
const url = require('url');
const FancyStorage = require('./fancyStorage.js');

let storage = new FancyStorage(); //TODO actually make fancy

let lables = ['channel-manager', 'channel-monitor'];
let networks = ['bitcoin', 'testnet', 'regtest', 'signet'];

let userDB = {
'token1': 'user1',
};

//TODO auth
//TODO rate limiting
//TODO file size limit
//TODO file count limit
//TODO logging

const server = http.createServer((req, res) => {
//TODO auth endpoint to get user access token

if (req.method === 'POST' && req.url.startsWith('/persist')) {
const urlParams = url.parse(req.url, true).query;

try {
validateParams(urlParams);
} catch (error) {
console.error(error);
res.writeHead(400, { 'Content-Type': 'text/plain' });
res.end(error.message);
return;
}

const network = urlParams.network;
const label = urlParams.label;
const channelId = urlParams.id;
const token = 'token1'; //urlParams.token;//TODO
const userId = userDB[token];

let body = Buffer.from([]);

req.on('data', (chunk) => {
body = Buffer.concat([body, chunk]);
});

req.on('end', () => {
console.log('Received backup for: ' + label + ' with size: ' + formatFileSize(body.length));

let key = label;
let subdir = '';
if (label == 'channel-monitor') {
key = channelId;
subdir = 'channel-monitors';
}

console.log("Saved");
console.log(body.length);

storage.set({userId, network, subdir, key, value: body});

res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end('success');
});

return;
}

if (req.method === 'GET' && req.url.startsWith('/retrieve')) {
const urlParams = url.parse(req.url, true).query;

try {
validateParams(urlParams);
} catch (error) {
console.error(error);
res.writeHead(400, { 'Content-Type': 'text/plain' });
res.end(error.message);
return;
}

const network = urlParams.network;
const label = urlParams.label;
const channelId = urlParams.id;
const token = 'token1'; //urlParams.token;//TODO
const userId = userDB[token];

let key = label;
let subdir = '';
if (label == 'channel-monitor') {
key = channelId;
subdir = 'channel-monitors';
}

const backup = storage.get({userId, network, subdir, key});
if (!backup) {
res.writeHead(404, { 'Content-Type': 'text/plain' });
res.end('Backup not found');
return;
}

console.log("Fetched");
console.log(backup.length);

res.writeHead(200, { 'Content-Type': 'application/octet-stream' });
res.end(backup, 'binary');
return;
}

//TODO expose list channel monitors

res.writeHead(405, { 'Content-Type': 'text/plain' });
res.end('Method not allowed');
console.log('URL not allowed: ' + req.url);
const start = require('./src/server');

const HOST = '0.0.0.0';
const PORT = 3003;
start(HOST, PORT).then(() => {
console.log("Server started");
}).catch((error) => {
process.exit(1);
});

server.listen(3003, () => {
console.log('Server is running on port 3003');
});

function validateParams(params) {
const network = params.network;
const label = params.label;
const channelId = params.id;
const token = params.id; //TODO

if (!network || !networks.includes(network)) {
throw Error(`Network must be one of: ${networks.join(', ')}`);
}

if (!label || !lables.includes(label)) {
throw Error(`Label must be one of: ${lables.join(', ')}`);
}

if (label === 'channel-monitor' && !channelId) {
throw Error('Missing channel id parameter');
}

// if (!token) {
// throw Error('Missing token parameter');
// }
}

function formatFileSize(bytes) {
if (bytes < 1024) {
return bytes + ' bytes';
} else if (bytes < 1024 * 1024) {
return (bytes / 1024).toFixed(2) + ' KB';
} else if (bytes < 1024 * 1024 * 1024) {
return (bytes / (1024 * 1024)).toFixed(2) + ' MB';
} else {
return (bytes / (1024 * 1024 * 1024)).toFixed(2) + ' GB';
}
}
Loading