forked from cory/tildefriends
		
	Run prettier.
This commit is contained in:
		| @@ -2,7 +2,7 @@ let g_about_cache = {}; | ||||
|  | ||||
| async function query(sql, args) { | ||||
| 	let result = []; | ||||
| 	await ssb.sqlAsync(sql, args, function(row) { | ||||
| 	await ssb.sqlAsync(sql, args, function (row) { | ||||
| 		result.push(row); | ||||
| 	}); | ||||
| 	return result; | ||||
| @@ -21,7 +21,8 @@ async function contacts_internal(id, last_row_id, following, max_row_id) { | ||||
| 				json_extract(content, '$.type') = 'contact' | ||||
| 				ORDER BY sequence | ||||
| 			`, | ||||
| 		[id, last_row_id, max_row_id]); | ||||
| 		[id, last_row_id, max_row_id] | ||||
| 	); | ||||
| 	for (let row of contacts) { | ||||
| 		let contact = JSON.parse(row.content); | ||||
| 		if (contact.following === true) { | ||||
| @@ -42,15 +43,34 @@ async function contact(id, last_row_id, following, max_row_id) { | ||||
| 	return await contacts_internal(id, last_row_id, following, max_row_id); | ||||
| } | ||||
|  | ||||
| async function following_deep_internal(ids, depth, blocking, last_row_id, following, max_row_id) { | ||||
| 	let contacts = await Promise.all([...new Set(ids)].map(x => contact(x, last_row_id, following, max_row_id))); | ||||
| async function following_deep_internal( | ||||
| 	ids, | ||||
| 	depth, | ||||
| 	blocking, | ||||
| 	last_row_id, | ||||
| 	following, | ||||
| 	max_row_id | ||||
| ) { | ||||
| 	let contacts = await Promise.all( | ||||
| 		[...new Set(ids)].map((x) => contact(x, last_row_id, following, max_row_id)) | ||||
| 	); | ||||
| 	let result = {}; | ||||
| 	for (let i = 0; i < ids.length; i++) { | ||||
| 		let id = ids[i]; | ||||
| 		let contact = contacts[i]; | ||||
| 		let all_blocking = Object.assign({}, contact.blocking, blocking); | ||||
| 		let found = Object.keys(contact.following).filter(y => !all_blocking[y]); | ||||
| 		let deeper = depth > 1 ? await following_deep_internal(found, depth - 1, all_blocking, last_row_id, following, max_row_id) : []; | ||||
| 		let found = Object.keys(contact.following).filter((y) => !all_blocking[y]); | ||||
| 		let deeper = | ||||
| 			depth > 1 | ||||
| 				? await following_deep_internal( | ||||
| 						found, | ||||
| 						depth - 1, | ||||
| 						all_blocking, | ||||
| 						last_row_id, | ||||
| 						following, | ||||
| 						max_row_id | ||||
| 					) | ||||
| 				: []; | ||||
| 		result[id] = [id, ...found, ...deeper]; | ||||
| 	} | ||||
| 	return [...new Set(Object.values(result).flat())]; | ||||
| @@ -68,10 +88,22 @@ async function following_deep(ids, depth, blocking) { | ||||
| 			last_row_id: 0, | ||||
| 		}; | ||||
| 	} | ||||
| 	let max_row_id = (await query(` | ||||
| 	let max_row_id = ( | ||||
| 		await query( | ||||
| 			` | ||||
| 			SELECT MAX(rowid) AS max_row_id FROM messages | ||||
| 		`, []))[0].max_row_id; | ||||
| 	let result = await following_deep_internal(ids, depth, blocking, cache.last_row_id, cache.following, max_row_id); | ||||
| 		`, | ||||
| 			[] | ||||
| 		) | ||||
| 	)[0].max_row_id; | ||||
| 	let result = await following_deep_internal( | ||||
| 		ids, | ||||
| 		depth, | ||||
| 		blocking, | ||||
| 		cache.last_row_id, | ||||
| 		cache.following, | ||||
| 		max_row_id | ||||
| 	); | ||||
| 	cache.last_row_id = max_row_id; | ||||
| 	let store = JSON.stringify(cache); | ||||
| 	await db.set('following', store); | ||||
| @@ -90,13 +122,15 @@ async function fetch_about(db, ids, users) { | ||||
| 		}; | ||||
| 	} | ||||
| 	let max_row_id = 0; | ||||
| 	await ssb.sqlAsync(` | ||||
| 	await ssb.sqlAsync( | ||||
| 		` | ||||
| 			SELECT MAX(rowid) AS max_row_id FROM messages | ||||
| 		`, | ||||
| 		[], | ||||
| 		function(row) { | ||||
| 		function (row) { | ||||
| 			max_row_id = row.max_row_id; | ||||
| 		}); | ||||
| 		} | ||||
| 	); | ||||
| 	for (let id of Object.keys(cache.about)) { | ||||
| 		if (ids.indexOf(id) == -1) { | ||||
| 			delete cache.about[id]; | ||||
| @@ -129,17 +163,21 @@ async function fetch_about(db, ids, users) { | ||||
| 				ORDER BY messages.author, messages.sequence | ||||
| 			`, | ||||
| 		[ | ||||
| 			JSON.stringify(ids.filter(id => cache.about[id])), | ||||
| 			JSON.stringify(ids.filter(id => !cache.about[id])), | ||||
| 			JSON.stringify(ids.filter((id) => cache.about[id])), | ||||
| 			JSON.stringify(ids.filter((id) => !cache.about[id])), | ||||
| 			cache.last_row_id, | ||||
| 			max_row_id, | ||||
| 		]); | ||||
| 		] | ||||
| 	); | ||||
| 	for (let about of abouts) { | ||||
| 		let content = JSON.parse(about.content); | ||||
| 		if (content.about === about.author) { | ||||
| 			delete content.type; | ||||
| 			delete content.about; | ||||
| 			cache.about[about.author] = Object.assign(cache.about[about.author] || {}, content); | ||||
| 			cache.about[about.author] = Object.assign( | ||||
| 				cache.about[about.author] || {}, | ||||
| 				content | ||||
| 			); | ||||
| 		} | ||||
| 	} | ||||
| 	cache.last_row_id = max_row_id; | ||||
| @@ -155,41 +193,41 @@ async function getAbout(db, id) { | ||||
| 	if (g_about_cache[id]) { | ||||
| 		return g_about_cache[id]; | ||||
| 	} | ||||
| 	let o = await db.get(id + ":about"); | ||||
| 	let o = await db.get(id + ':about'); | ||||
| 	const k_version = 4; | ||||
| 	let f = o ? JSON.parse(o) : o; | ||||
| 	if (!f || f.version != k_version) { | ||||
| 		f = {about: {}, sequence: 0, version: k_version}; | ||||
| 	} | ||||
| 	await ssb.sqlAsync( | ||||
| 		"SELECT "+ | ||||
| 		"  sequence, "+ | ||||
| 		"  content "+ | ||||
| 		"FROM messages "+ | ||||
| 		"WHERE "+ | ||||
| 		"  author = ?1 AND "+ | ||||
| 		"  sequence > ?2 AND "+ | ||||
| 		"  json_extract(content, '$.type') = 'about' AND "+ | ||||
| 		"  json_extract(content, '$.about') = ?1 "+ | ||||
| 		"UNION SELECT MAX(sequence) as sequence, NULL FROM messages WHERE author = ?1 "+ | ||||
| 		"ORDER BY sequence", | ||||
| 		'SELECT ' + | ||||
| 			'  sequence, ' + | ||||
| 			'  content ' + | ||||
| 			'FROM messages ' + | ||||
| 			'WHERE ' + | ||||
| 			'  author = ?1 AND ' + | ||||
| 			'  sequence > ?2 AND ' + | ||||
| 			"  json_extract(content, '$.type') = 'about' AND " + | ||||
| 			"  json_extract(content, '$.about') = ?1 " + | ||||
| 			'UNION SELECT MAX(sequence) as sequence, NULL FROM messages WHERE author = ?1 ' + | ||||
| 			'ORDER BY sequence', | ||||
| 		[id, f.sequence], | ||||
| 		function(row) { | ||||
| 		function (row) { | ||||
| 			f.sequence = row.sequence; | ||||
| 			if (row.content) { | ||||
| 				let about = {}; | ||||
| 				try { | ||||
| 					about = JSON.parse(row.content); | ||||
| 				} catch { | ||||
| 				} | ||||
| 				} catch {} | ||||
| 				delete about.about; | ||||
| 				delete about.type; | ||||
| 				f.about = Object.assign(f.about, about); | ||||
| 			} | ||||
| 		}); | ||||
| 		} | ||||
| 	); | ||||
| 	let j = JSON.stringify(f); | ||||
| 	if (o != j) { | ||||
| 		await db.set(id + ":about", j); | ||||
| 		await db.set(id + ':about', j); | ||||
| 	} | ||||
| 	g_about_cache[id] = f.about; | ||||
| 	return f.about; | ||||
| @@ -198,15 +236,15 @@ async function getAbout(db, id) { | ||||
| async function getSize(db, id) { | ||||
| 	let size = 0; | ||||
| 	await ssb.sqlAsync( | ||||
| 		"SELECT (LENGTH(author) * COUNT(*) + SUM(LENGTH(content)) + SUM(LENGTH(id))) AS size FROM messages WHERE author = ?1", | ||||
| 		'SELECT (LENGTH(author) * COUNT(*) + SUM(LENGTH(content)) + SUM(LENGTH(id))) AS size FROM messages WHERE author = ?1', | ||||
| 		[id], | ||||
| 		function (row) { | ||||
| 			size += row.size; | ||||
| 		}); | ||||
| 		} | ||||
| 	); | ||||
| 	return size; | ||||
| } | ||||
|  | ||||
|  | ||||
| async function getSizes(ids) { | ||||
| 	let sizes = {}; | ||||
| 	await ssb.sqlAsync( | ||||
| @@ -221,7 +259,8 @@ async function getSizes(ids) { | ||||
| 		[JSON.stringify(ids)], | ||||
| 		function (row) { | ||||
| 			sizes[row.author] = row.size; | ||||
| 		}); | ||||
| 		} | ||||
| 	); | ||||
| 	return sizes; | ||||
| } | ||||
|  | ||||
| @@ -241,7 +280,10 @@ function niceSize(bytes) { | ||||
| } | ||||
|  | ||||
| function escape(value) { | ||||
| 	return value.replaceAll('&', '&').replaceAll('<', '<').replaceAll('>', '>'); | ||||
| 	return value | ||||
| 		.replaceAll('&', '&') | ||||
| 		.replaceAll('<', '<') | ||||
| 		.replaceAll('>', '>'); | ||||
| } | ||||
|  | ||||
| async function main() { | ||||
| @@ -249,19 +291,27 @@ async function main() { | ||||
| 	let db = await database('ssb'); | ||||
| 	let whoami = await ssb.getIdentities(); | ||||
| 	let tree = ''; | ||||
| 	await app.setDocument(`<pre style="color: #fff">Enumerating followed users...</pre>`); | ||||
| 	await app.setDocument( | ||||
| 		`<pre style="color: #fff">Enumerating followed users...</pre>` | ||||
| 	); | ||||
| 	let following = await following_deep(whoami, 2, {}); | ||||
| 	await app.setDocument(`<pre style="color: #fff">Getting names and sizes...</pre>`); | ||||
| 	await app.setDocument( | ||||
| 		`<pre style="color: #fff">Getting names and sizes...</pre>` | ||||
| 	); | ||||
| 	let [about, sizes] = await Promise.all([ | ||||
| 		fetch_about(db, following, {}), | ||||
| 		getSizes(following), | ||||
| 	]); | ||||
| 	await app.setDocument(`<pre style="color: #fff">Finishing...</pre>`); | ||||
| 	following.sort((a, b) => ((sizes[b] ?? 0) - (sizes[a] ?? 0))); | ||||
| 	following.sort((a, b) => (sizes[b] ?? 0) - (sizes[a] ?? 0)); | ||||
| 	for (let id of following) { | ||||
| 		tree += `<li><a href="/~core/ssb/#${id}">${escape(about[id]?.name ?? id)}</a> ${niceSize(sizes[id] ?? 0)}</li>\n`; | ||||
| 	} | ||||
| 	await app.setDocument('<!DOCTYPE html>\n<html>\n<body style="color: #fff"><h1>Following</h1>\n<ul>' + tree + '</ul>\n</body>\n</html>'); | ||||
| 	await app.setDocument( | ||||
| 		'<!DOCTYPE html>\n<html>\n<body style="color: #fff"><h1>Following</h1>\n<ul>' + | ||||
| 			tree + | ||||
| 			'</ul>\n</body>\n</html>' | ||||
| 	); | ||||
| } | ||||
|  | ||||
| main(); | ||||
| main(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user