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.
NodePress is a lightweight blog engine for node.js. At its current state it is useful as a compact library or boilerplate for a modular and extendible blog engine.
NodePress' web server is built on top of node-router. What is added on top of the server is a plugin functionality which renders one, or multiple, pair or individual set of client and server endpoints. Client endpoints being react components. This can be seen in any of the core plugin implementations, on /src/plugins
.
NodePress relies on a plugin system to function. A plugin is an object that indexes frontend (React components) and backend (Fastify routes) endpoints to be served via the server. For that reason, NodePress allows for easily extendible and naturally modular projects.
By default, NodePress contains five plugins which make up a simple blog engine that renders markdown and latex math equations (using marked and katex). Those plugins are reader
, feed
, fetch
, post
, and user
. You can take a look at the source of those plugins here. The user
plugin contains essential user authorisation and management, while the other four make up the blog engine. It is possible to ignore all those plugins by initialising NodePress with the boolean ignoreCorePlugins
. If you ignore core plugins, you can still manually load one or many of them, such as if you wish to use the user
plugin but not provide a blog.
const NodePress = require('NodePress');
const path = require('path');
const isDevEnv = process.argv.includes('--dev');
const args = {
// Make config.json and set it up with an actual MongoDB URI.
config: path.resolve(__dirname, 'config.json'),
// Path to body and head HTML files.
layout: {
body: path.resolve(__dirname, 'layout/body.html'),
head: path.resolve(__dirname, 'layout/head.html')
},
// Do not add any plugins to this example...
plugins: [],
//...but do not ignore core plugins.
ignoreCorePlugins: false,
// If dev environment, run on HTTP instead of HTTPS.
dev: isDevEnv
};
// Start instance.
const instance = new NodePress(args);
{
"net": {
"interface": {
"ports": {
"https": 8080
},
"https": {
"cert": "./some/path/fullchain.pem",
"key": "./some/path/privkey.pem"
}
}
},
"db": {
"uri": "mongodb_uri"
},
"user": {
"root": {
"password": "root_user_password"
},
"secret": {
"key": "some_secret_encryption_key"
}
},
"api": {
"np_epoch": 1550620800000
}
}
NodePress uses MongoDB for database and Mongoose as interface by default.
The following is the default structure of a post object, as used by the core post
, reader
, fetch
and feed
plugins.
{
_id: ObjectId
title: string
content: string
metadata: {
date: Date
author: string
...
}
}
MIT
FAQs
Lightweight blog engine for node
We found that nodepress demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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.