1
0
Fork 0
mirror of https://github.com/alangrainger/immich-public-proxy.git synced 2025-01-16 12:56:45 +01:00

Simplify code for readability

This commit is contained in:
Alan Grainger 2024-11-12 19:47:40 +01:00
parent bd7e4f4e6a
commit d5400c9a21

View file

@ -16,14 +16,18 @@ app.use(express.json())
// Serve static assets from the /public folder // Serve static assets from the /public folder
app.use(express.static('public', { setHeaders: addResponseHeaders })) app.use(express.static('public', { setHeaders: addResponseHeaders }))
// An incoming request for a shared link /*
* [ROUTE] An incoming request for a shared link
*/
app.get('/share/:key', async (req, res) => { app.get('/share/:key', async (req, res) => {
await immich.handleShareRequest({ await immich.handleShareRequest({
key: req.params.key key: req.params.key
}, res) }, res)
}) })
// Receive an unlock request from the password page /*
* [ROUTE] Receive an unlock request from the password page
*/
app.post('/unlock', async (req, res) => { app.post('/unlock', async (req, res) => {
await immich.handleShareRequest({ await immich.handleShareRequest({
key: toString(req.body.key), key: toString(req.body.key),
@ -31,19 +35,29 @@ app.post('/unlock', async (req, res) => {
}, res) }, res)
}) })
// Output the buffer data for a photo or video /*
* [ROUTE] Output the buffer data for a photo or video
*/
app.get('/:type(photo|video)/:key/:id/:size?', async (req, res) => { app.get('/:type(photo|video)/:key/:id/:size?', async (req, res) => {
// Add the headers configured in config.json (most likely `cache-control`)
addResponseHeaders(res) addResponseHeaders(res)
// Check for valid key and ID // Check for valid key and ID
if (immich.isKey(req.params.key) && immich.isId(req.params.id)) { if (!immich.isKey(req.params.key) || !immich.isId(req.params.id)) {
log('Invalid key or ID for ' + req.path)
res.status(404).send()
return
}
// Validate the size parameter // Validate the size parameter
if (req.params.size && !Object.values(ImageSize).includes(req.params.size as ImageSize)) { if (req.params.size && !Object.values(ImageSize).includes(req.params.size as ImageSize)) {
log('Invalid size parameter ' + req.path) log('Invalid size parameter ' + req.path)
res.status(404).send() res.status(404).send()
return return
} }
let password
// Validate the password payload, if one was provided // Validate the password payload, if one was provided
let password
if (req.query?.cr && req.query?.iv) { if (req.query?.cr && req.query?.iv) {
try { try {
const payload = JSON.parse(decrypt({ const payload = JSON.parse(decrypt({
@ -54,27 +68,36 @@ app.get('/:type(photo|video)/:key/:id/:size?', async (req, res) => {
password = payload.password password = payload.password
} else { } else {
log(`Attempted to load assets from ${req.params.key} with an expired decryption token`) log(`Attempted to load assets from ${req.params.key} with an expired decryption token`)
// Send 404 rather than 401 so as not to provide information to an attacker that there is "something" at this path
res.status(404).send()
return
} }
} catch (e) { } } catch (e) { }
} }
// Check if the key is a valid share link
// Fetch the shared link information from Immich, so we can check to make sure that the requested asset
// is allowed by this shared link.
const sharedLink = (await immich.getShareByKey(req.params.key, password))?.link const sharedLink = (await immich.getShareByKey(req.params.key, password))?.link
const request = { key: req.params.key, range: req.headers.range || '' } const request = {
key: req.params.key,
range: req.headers.range || ''
}
if (sharedLink?.assets.length) { if (sharedLink?.assets.length) {
// Check that the requested asset exists in this share // Check that the requested asset exists in this share
const asset = sharedLink.assets.find(x => x.id === req.params.id) const asset = sharedLink.assets.find(x => x.id === req.params.id)
if (asset) { if (asset) {
asset.type = req.params.type === 'video' ? AssetType.video : AssetType.image asset.type = req.params.type === 'video' ? AssetType.video : AssetType.image
render.assetBuffer(request, res, asset, req.params.size).then() render.assetBuffer(request, res, asset, req.params.size).then()
return
}
}
} }
} else {
log('No asset found for ' + req.path) log('No asset found for ' + req.path)
res.status(404).send() res.status(404).send()
}
}) })
// Healthcheck /*
* [ROUTE] Healthcheck
*/
app.get('/healthcheck', async (_req, res) => { app.get('/healthcheck', async (_req, res) => {
if (await immich.accessible()) { if (await immich.accessible()) {
res.send('ok') res.send('ok')
@ -83,12 +106,15 @@ app.get('/healthcheck', async (_req, res) => {
} }
}) })
// Send a 404 for all other routes /*
* Send a 404 for all other routes
*/
app.get('*', (req, res) => { app.get('*', (req, res) => {
log('Invalid route ' + req.path) log('Invalid route ' + req.path)
res.status(404).send() res.status(404).send()
}) })
// Start the ExpressJS server
app.listen(3000, () => { app.listen(3000, () => {
console.log(dayjs().format() + ' Server started') console.log(dayjs().format() + ' Server started')
}) })