mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-05 20:03:15 +00:00
Merge pull request #4104 from overleaf/jpa-pdf-object-caching
[misc] serviceWorker: back fill object context when sent by the backend GitOrigin-RevId: 1bddbff9b2c996ec71f9c493e6896a22d1e27560
This commit is contained in:
parent
12eb7b38a2
commit
d6454a84bb
1 changed files with 36 additions and 5 deletions
|
@ -133,7 +133,7 @@ function processPdfRequest(
|
|||
|
||||
const verifyChunks = event.request.url.includes('verify_chunks=true')
|
||||
const rangeHeader =
|
||||
event.request.headers.get('Range') || `bytes=0-${file.size}`
|
||||
event.request.headers.get('Range') || `bytes=0-${file.size - 1}`
|
||||
const [start, last] = rangeHeader
|
||||
.slice('bytes='.length)
|
||||
.split('-')
|
||||
|
@ -204,12 +204,15 @@ function processPdfRequest(
|
|||
return response.arrayBuffer()
|
||||
})
|
||||
.then(arrayBuffer => {
|
||||
return { chunk, arrayBuffer }
|
||||
return {
|
||||
chunk,
|
||||
data: backFillObjectContext(chunk, arrayBuffer),
|
||||
}
|
||||
})
|
||||
)
|
||||
)
|
||||
.then(responses => {
|
||||
responses.forEach(({ chunk, arrayBuffer }) => {
|
||||
responses.forEach(({ chunk, data }) => {
|
||||
// overlap:
|
||||
// | REQUESTED_RANGE |
|
||||
// | CHUNK |
|
||||
|
@ -221,10 +224,10 @@ function processPdfRequest(
|
|||
if (offsetStart > 0 || offsetEnd > 0) {
|
||||
// compute index positions for slice to handle case where offsetEnd=0
|
||||
const chunkSize = chunk.end - chunk.start
|
||||
arrayBuffer = arrayBuffer.slice(offsetStart, chunkSize - offsetEnd)
|
||||
data = data.slice(offsetStart, chunkSize - offsetEnd)
|
||||
}
|
||||
const insertPosition = Math.max(chunk.start - start, 0)
|
||||
reAssembledBlob.set(new Uint8Array(arrayBuffer), insertPosition)
|
||||
reAssembledBlob.set(data, insertPosition)
|
||||
})
|
||||
|
||||
let verifyProcess = Promise.resolve(reAssembledBlob)
|
||||
|
@ -304,6 +307,7 @@ function handleCompileResponse(response, body) {
|
|||
for (const file of body.outputFiles) {
|
||||
if (file.path !== 'output.pdf') continue // not the pdf used for rendering
|
||||
if (file.ranges) {
|
||||
file.ranges.forEach(backFillEdgeBounds)
|
||||
const { clsiServerId, compileGroup } = body
|
||||
PDF_FILES.set(file.url, {
|
||||
pdfCreatedAt,
|
||||
|
@ -316,6 +320,33 @@ function handleCompileResponse(response, body) {
|
|||
}
|
||||
}
|
||||
|
||||
const ENCODER = new TextEncoder()
|
||||
function backFillEdgeBounds(chunk) {
|
||||
if (chunk.objectId) {
|
||||
chunk.objectId = ENCODER.encode(chunk.objectId)
|
||||
chunk.start -= chunk.objectId.byteLength
|
||||
}
|
||||
return chunk
|
||||
}
|
||||
|
||||
/**
|
||||
* @param chunk
|
||||
* @param {ArrayBuffer} arrayBuffer
|
||||
* @return {Uint8Array}
|
||||
*/
|
||||
function backFillObjectContext(chunk, arrayBuffer) {
|
||||
if (!chunk.objectId) {
|
||||
// This is a dynamic chunk
|
||||
return new Uint8Array(arrayBuffer)
|
||||
}
|
||||
const { start, end, objectId } = chunk
|
||||
const header = Uint8Array.from(objectId)
|
||||
const fullBuffer = new Uint8Array(end - start)
|
||||
fullBuffer.set(header, 0)
|
||||
fullBuffer.set(new Uint8Array(arrayBuffer), objectId.length)
|
||||
return fullBuffer
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {Array} chunks
|
||||
* @param {number} start
|
||||
|
|
Loading…
Reference in a new issue