
Security News
pnpm 11.5 Adds Support for Recognizing npm Staged Publishes
pnpm 11.5 now recognizes npm staged publish approvals in release metadata, preventing those releases from being mistaken for lower-trust package publishes.
@ttoss/http-server
Advanced tools
Lightweight HTTP server built on Koa for the ttoss ecosystem.
pnpm add @ttoss/http-server
import { App, Router, bodyParser, cors, serve } from '@ttoss/http-server';
const app = new App();
app.use(cors());
app.use(bodyParser());
const router = new Router();
router.get('/health', (ctx) => {
ctx.body = { status: 'ok' };
});
app.use(router.routes());
app.use(router.allowedMethods());
app.listen(3000, () => {
console.log('Server running on http://localhost:3000');
});
Add a health check endpoint with a single line:
import { App, addHealthCheck } from '@ttoss/http-server';
const app = new App();
addHealthCheck({ app });
// or with custom path: addHealthCheck({ app, path: '/healthz' });
app.listen(3000);
// GET /health returns { status: 'ok' }
Serve static files from a directory using the serve middleware:
import { App, serve } from '@ttoss/http-server';
const app = new App();
// Serve files from the 'public' directory
app.use(serve('./public'));
app.listen(3000);
// Files in ./public are now accessible at http://localhost:3000
Advanced Options:
// With custom options
app.use(
serve('./public', {
maxage: 3600000, // Cache files for 1 hour (in milliseconds)
index: 'index.html', // Default file to serve for directories
hidden: false, // Don't serve hidden files
gzip: true, // Enable gzip compression
})
);
Combining with Routes:
import { App, Router, serve } from '@ttoss/http-server';
const app = new App();
const router = new Router();
// Define API routes first
router.get('/api/users', (ctx) => {
ctx.body = [{ id: 1, name: 'John' }];
});
app.use(router.routes());
// Static files are served after API routes
app.use(serve('./public'));
app.listen(3000);
router.get('/users/:id', (ctx) => {
const { id } = ctx.params;
ctx.body = { userId: id };
});
JSON and form-urlencoded data are automatically parsed when using bodyParser():
router.post('/users', (ctx) => {
const userData = ctx.request.body;
ctx.body = { created: userData };
});
import { multer } from '@ttoss/http-server';
import type { MulterFile } from '@ttoss/http-server';
const upload = multer();
router.post('/upload', upload.single('file'), (ctx) => {
const file = ctx.file as MulterFile | undefined;
ctx.body = {
filename: file?.originalname,
size: file?.size,
};
});
app.use(async (ctx, next) => {
try {
await next();
} catch (error) {
ctx.status = error.status || 500;
ctx.body = { error: error.message };
}
});
All exports are re-exported from established Koa ecosystem packages:
App - Koa applicationRouter - Koa router for routingbodyParser - Koa body parser for JSON/form parsingcors - Koa CORS for cross-origin requestsmulter - Koa multer for file uploadsserve - Koa static for serving static filesaddHealthCheck({ app, path? }) - Adds a health endpoint (defaults to /health) returning { status: 'ok' }MulterFile (type) - File type for uploaded filesRouterContext<StateT, ContextT> (type) - Generic Koa router context for type-safe route handlersFAQs
HTTP Server for ttoss environment
The npm package @ttoss/http-server receives a total of 229 weekly downloads. As such, @ttoss/http-server popularity was classified as not popular.
We found that @ttoss/http-server demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 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
pnpm 11.5 now recognizes npm staged publish approvals in release metadata, preventing those releases from being mistaken for lower-trust package publishes.

Security News
Federal audit finds NIST lacked a plan to clear the NVD backlog, wasted funds on duplicate work, and delayed use of CISA data.

Research
/Security News
A mini Shai-Hulud campaign compromised Red Hat Cloud Services npm packages to steal developer and CI/CD secrets during installation.