Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
r2-streamer-js
Advanced tools
Readium 2 'streamer' for NodeJS (TypeScript, ECMAScript 2015 / ES6)
NodeJS implementation (TypeScript transpiled to ECMAScript 2015 / ES6) of https://github.com/readium/readium-2/tree/master/streamer
THIS IS ALPHA SOFTWARE! Do not use in production. APIs are not stable, the architecture / code organization is likely to change frequently. All builds are from the develop
branch. Continuous integration via TravisCI. NodeJS package published at the NPM registry. Test server apps deployed at Heroku and Now.sh.
node --version
and npm --version
from the command line)yarn --version
from the command line)https://www.npmjs.com/package/r2-streamer-js
yarn add r2-streamer-js
or npm install r2-streamer-js
...or manually, in your project's package.json
:
"dependencies": {
"r2-streamer-js": "latest"
}
In your Javascript code (ECMAScript 2015 / ES6) or TypeScript code (all *.d.ts
type definitions are included in ./node_modules/r2-streamer-js/**
):
// see r2-streamer-js/dist/src/index.d.ts for exported types:
import { * } from "r2-streamer-js";
// ... or specific, direct type import, e.g.:
import { Publication } from "r2-streamer-js/dist/src/models/publication";
Command line steps:
cd r2-streamer-js
npm update --global
(sync NPM global packages)yarn global upgrade
(sync Yarn global packages)yarn install
(initialize local node_modules
packages from dependencies declared in package.json
)yarn upgrade
(sync local packages)yarn run build
(invoke the main build script: clean, lint, compile)yarn test
(run the unit tests)yarn run cli {PATH_TO_EPUB_OR_DIR}
(command line publication "dump") (path is relative or absolute)yarn run server-debug {PATH_TO_EPUB_OR_DIR}
(HTTP micro-service to serve publication manifest and associated resources)Two active deployments, at Heroku and Now.sh:
https://readium2.herokuapp.com
https://readium2-mlowondbfb.now.sh
(all quoted HTTP routes below use the GET verb)
{PUB_ID}
is the base64 encoding of a local publication file (server filesystem, therefore limited to app-approved files), or of any arbitrary HTTP URL (see the "Support for remote publications" section below).
For demonstration purposes, the deployed server apps include wasteland-otf-obf.epub
and childrens-literature.epub
, obtained from https://idpf.github.io/epub3-samples/samples.html / https://github.com/IDPF/epub3-samples
This route serves the "webpub manifest" JSON file using the application/webpub+json
content type (canonical syntax, keys are recursively alphabetically sorted).
This route serves a pretty-printed representation of the "webpub manifest" JSON, with clickable links for easy navigation into individual publication assets (see next route below).
/show
is equivalent to /show/all
. Here is a list of available JSON "filters": Cover image: /cover
, Table of Contents: /toc
, Metadata: /metadata
, Spine: /spine
, Page List: /pagelist
, Landmarks: /landmarks
, Links: /links
, Resources: /resources
, Media Overlays: /mediaoverlays
.
This route serves individual assets (file resources) from the publication archive. {ASSET_PATH}
is relative to the root of the publication container (e.g. EPUB zip archive), so files like /META-INF/container.xml
can be requested.
Text files can be rendered in-page (for debugging) rather than processed by the web browser, by using the ?show=1
URL query string parameter.
This route serves the full EPUB3 Media Overlay SMIL data (in its JSON form) using the application/vnd.readium.mo+json
content type. Single spine item Media Overlays can be requested using the /media-overlay?resource={ASSET_PATH}
URL query parameter ({ASSET_PATH}
has the same definition as in the above section).
This conveninent micro-service automatically redirects to the base64 route described in the above section (/pub/{PUB_ID}
). Also see the "Support for remote publications" section below.
This micro-service provides a basic OPDS reader. See the "Support for OPDS feeds" section below
See: https://github.com/edrlab/r2-streamer-js/blob/develop/docs/remote-epub.md
See: https://github.com/edrlab/r2-streamer-js/blob/develop/docs/opds.md
FAQs
Readium 2 'streamer' for NodeJS (TypeScript)
The npm package r2-streamer-js receives a total of 556 weekly downloads. As such, r2-streamer-js popularity was classified as not popular.
We found that r2-streamer-js demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.