fix(metadata): Updated package and npmextra.json metadata fields for clarity
This commit is contained in:
parent
396cfe70de
commit
fe4c75da38
14
changelog.md
Normal file
14
changelog.md
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
# Changelog
|
||||||
|
|
||||||
|
## 2025-01-01 - 2.0.62 - fix(metadata)
|
||||||
|
Updated package and npmextra.json metadata fields for clarity
|
||||||
|
|
||||||
|
- Updated description and added keywords in package.json and npmextra.json
|
||||||
|
- Clarified project metadata to streamline categorization and searchability
|
||||||
|
|
||||||
|
Since the commit "initial" lacks enough detail or relevant changes, it can be omitted from the changelog. The version 2.0.61 does not have any significant entries to document.
|
||||||
|
|
||||||
|
|
||||||
|
## 2025-01-01 - 2.0.61 - No significant changes
|
||||||
|
|
||||||
|
Version 2.0.61 did not include any notable updates or changes worth documenting.
|
@ -15,9 +15,24 @@
|
|||||||
"githost": "code.foss.global",
|
"githost": "code.foss.global",
|
||||||
"gitscope": "serve.zone",
|
"gitscope": "serve.zone",
|
||||||
"gitrepo": "corerender",
|
"gitrepo": "corerender",
|
||||||
"description": "a rendering service for serve.zone that preserves styles for web components",
|
"description": "A rendering service designed for serve.zone that efficiently preserves styles while rendering web components.",
|
||||||
"npmPackagename": "@serve.zone/corerender",
|
"npmPackagename": "@serve.zone/corerender",
|
||||||
"license": "MIT"
|
"license": "MIT",
|
||||||
|
"keywords": [
|
||||||
|
"rendering",
|
||||||
|
"web components",
|
||||||
|
"style preservation",
|
||||||
|
"TypeScript",
|
||||||
|
"SSR",
|
||||||
|
"prerendering",
|
||||||
|
"task scheduling",
|
||||||
|
"web application",
|
||||||
|
"service integration",
|
||||||
|
"database management",
|
||||||
|
"sitemap parsing",
|
||||||
|
"robots.txt",
|
||||||
|
"node.js"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
19
package.json
19
package.json
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "corerender",
|
"name": "corerender",
|
||||||
"version": "2.0.61",
|
"version": "2.0.61",
|
||||||
"description": "a rendering service for serve.zone that preserves styles for web components",
|
"description": "A rendering service designed for serve.zone that efficiently preserves styles while rendering web components.",
|
||||||
"main": "dist_ts/index.js",
|
"main": "dist_ts/index.js",
|
||||||
"typings": "dist_ts/index.d.ts",
|
"typings": "dist_ts/index.d.ts",
|
||||||
"author": "Lossless GmbH",
|
"author": "Lossless GmbH",
|
||||||
@ -53,5 +53,20 @@
|
|||||||
"browserslist": [
|
"browserslist": [
|
||||||
"last 1 chrome versions"
|
"last 1 chrome versions"
|
||||||
],
|
],
|
||||||
"type": "module"
|
"type": "module",
|
||||||
|
"keywords": [
|
||||||
|
"rendering",
|
||||||
|
"web components",
|
||||||
|
"style preservation",
|
||||||
|
"TypeScript",
|
||||||
|
"SSR",
|
||||||
|
"prerendering",
|
||||||
|
"task scheduling",
|
||||||
|
"web application",
|
||||||
|
"service integration",
|
||||||
|
"database management",
|
||||||
|
"sitemap parsing",
|
||||||
|
"robots.txt",
|
||||||
|
"node.js"
|
||||||
|
]
|
||||||
}
|
}
|
0
readme.hints.md
Normal file
0
readme.hints.md
Normal file
194
readme.md
194
readme.md
@ -1,32 +1,176 @@
|
|||||||
# @losslessone/services/servezone/rendertron
|
# Corerender
|
||||||
a rendering service for lossless gmbh
|
A rendering service for serve.zone that preserves styles for web components.
|
||||||
|
|
||||||
## Availabililty and Links
|
## Install
|
||||||
* [npmjs.org (npm package)](https://www.npmjs.com/package/@losslessone_private/rendertron)
|
|
||||||
* [gitlab.com (source)](https://gitlab.com/losslessone/services/servezone/rendertron)
|
|
||||||
* [github.com (source mirror)](https://github.com/losslessone/services/servezone/rendertron)
|
|
||||||
* [docs (typedoc)](https://losslessone/services/servezone.gitlab.io/rendertron/)
|
|
||||||
|
|
||||||
## Status for master
|
To install Corerender in your project, you can use npm. Make sure you have Node.js installed and then run the following command in your terminal:
|
||||||
|
|
||||||
Status Category | Status Badge
|
```shell
|
||||||
-- | --
|
npm install corerender
|
||||||
GitLab Pipelines | [![pipeline status](https://gitlab.com/losslessone/services/servezone/rendertron/badges/master/pipeline.svg)](https://lossless.cloud)
|
```
|
||||||
GitLab Pipline Test Coverage | [![coverage report](https://gitlab.com/losslessone/services/servezone/rendertron/badges/master/coverage.svg)](https://lossless.cloud)
|
|
||||||
npm | [![npm downloads per month](https://badgen.net/npm/dy/@losslessone_private/rendertron)](https://lossless.cloud)
|
This will add `corerender` as a dependency to your project, allowing you to use its rendering services to preserve styles for web components efficiently.
|
||||||
Snyk | [![Known Vulnerabilities](https://badgen.net/snyk/losslessone/services/servezone/rendertron)](https://lossless.cloud)
|
|
||||||
TypeScript Support | [![TypeScript](https://badgen.net/badge/TypeScript/>=%203.x/blue?icon=typescript)](https://lossless.cloud)
|
|
||||||
node Support | [![node](https://img.shields.io/badge/node->=%2010.x.x-blue.svg)](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
|
||||||
Code Style | [![Code Style](https://badgen.net/badge/style/prettier/purple)](https://lossless.cloud)
|
|
||||||
PackagePhobia (total standalone install weight) | [![PackagePhobia](https://badgen.net/packagephobia/install/@losslessone_private/rendertron)](https://lossless.cloud)
|
|
||||||
PackagePhobia (package size on registry) | [![PackagePhobia](https://badgen.net/packagephobia/publish/@losslessone_private/rendertron)](https://lossless.cloud)
|
|
||||||
BundlePhobia (total size when bundled) | [![BundlePhobia](https://badgen.net/bundlephobia/minzip/@losslessone_private/rendertron)](https://lossless.cloud)
|
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
Use TypeScript for best in class intellisense.
|
Welcome to the comprehensive usage guide for `corerender`, a powerful rendering service designed to integrate seamlessly within your web applications, ensuring that styles for web components are preserved properly. The guide is structured to provide a thorough understanding of `corerender`'s capabilities, demonstrating its flexibility and efficiency through realistic scenarios.
|
||||||
For further information read the linked docs at the top of this readme.
|
|
||||||
|
|
||||||
## Legal
|
### Setting Up Your Environment
|
||||||
> UNLICENSED licensed | **©** [Task Venture Capital GmbH](https://task.vc)
|
|
||||||
| By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy)
|
First things first, let’s get `corerender` up and running in your project. Ensure you've installed the package as detailed in the [Install](#install) section. Since `corerender` is a TypeScript-friendly library, it is recommended to use TypeScript for development to leverage the full power of type safety and IntelliSense.
|
||||||
|
|
||||||
|
### Basic Render Service Setup
|
||||||
|
|
||||||
|
```typescript
|
||||||
|
import { Rendertron } from 'corerender';
|
||||||
|
|
||||||
|
const rendertronInstance = new Rendertron();
|
||||||
|
|
||||||
|
(async () => {
|
||||||
|
console.log('Starting rendertron...');
|
||||||
|
await rendertronInstance.start();
|
||||||
|
console.log('Rendertron started successfully!');
|
||||||
|
})();
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
The code initializes an instance of `Rendertron` and starts the service asynchronously. `Rendertron` is the core class responsible for managing the rendering processes, including task scheduling and storing rendering results persistently in a database.
|
||||||
|
|
||||||
|
### Understanding the Rendertron Architecture
|
||||||
|
|
||||||
|
The architecture of `Rendertron` is designed to support web component rendering through several integral components:
|
||||||
|
|
||||||
|
1. **Prerender Manager**: Manages the creation and retrieval of prerender results.
|
||||||
|
2. **Task Manager**: Handles scheduling tasks for prerendering operations and cleanup routines.
|
||||||
|
3. **Utility Service Server**: Provides the server interface that accepts/render requests and serves prerendered content efficiently.
|
||||||
|
|
||||||
|
### Using the Prerender Manager
|
||||||
|
|
||||||
|
The `PrerenderManager` is responsible for generating and caching the rendering results of webpages. Here’s how you can use the `PrerenderManager` to prerender a webpage:
|
||||||
|
|
||||||
|
```typescript
|
||||||
|
import { PrerenderManager } from 'corerender/dist_ts/rendertron.classes.prerendermanager';
|
||||||
|
|
||||||
|
(async () => {
|
||||||
|
const prerenderManager = new PrerenderManager();
|
||||||
|
await prerenderManager.start();
|
||||||
|
|
||||||
|
const urlToPrerender = 'https://example.com';
|
||||||
|
const prerenderResult = await prerenderManager.getPrerenderResultForUrl(urlToPrerender);
|
||||||
|
console.log(`Prerendered content for ${urlToPrerender}:`);
|
||||||
|
console.log(prerenderResult);
|
||||||
|
|
||||||
|
await prerenderManager.stop();
|
||||||
|
})();
|
||||||
|
```
|
||||||
|
|
||||||
|
The above script demonstrates accessing a webpage's prerendered content. It initializes the `PrerenderManager`, specifies a URL, and requests the rendering result, which is stored or retrieved from the database.
|
||||||
|
|
||||||
|
### Scheduling Prerendering Tasks
|
||||||
|
|
||||||
|
The `TaskManager` class allows for efficiently scheduling tasks, such as regular prerendering of local domains and cleanup of outdated render results:
|
||||||
|
|
||||||
|
```typescript
|
||||||
|
import { TaskManager } from 'corerender/dist_ts/rendertron.taskmanager';
|
||||||
|
|
||||||
|
const taskManager = new TaskManager(rendertronInstance);
|
||||||
|
taskManager.start();
|
||||||
|
|
||||||
|
// Example: Manual trigger of a specific task
|
||||||
|
taskManager.triggerTaskByName('prerenderLocalDomains');
|
||||||
|
|
||||||
|
taskManager.stop();
|
||||||
|
```
|
||||||
|
|
||||||
|
`TaskManager` works closely with the `Rendertron` service to ensure tasks are executed as per defined schedules (e.g., every 30 minutes or daily). It allows manual triggering for immediate execution outside the schedule.
|
||||||
|
|
||||||
|
### Managing Render Results
|
||||||
|
|
||||||
|
The pre-rendered results are stored using `smartdata`’s `SmartDataDbDoc`. You may need advanced control over whether these are retrieved, created anew, or updated:
|
||||||
|
|
||||||
|
```typescript
|
||||||
|
import { PrerenderResult } from 'corerender/dist_ts/rendertron.classes.prerenderresult';
|
||||||
|
|
||||||
|
(async () => {
|
||||||
|
const url = 'https://example.com';
|
||||||
|
let prerenderResult = await PrerenderResult.getPrerenderResultForUrl(prerenderManager, url);
|
||||||
|
|
||||||
|
// Check if an updated result is necessary
|
||||||
|
if (prerenderResultNeedsUpdate(prerenderResult)) {
|
||||||
|
prerenderResult = await PrerenderResult.createPrerenderResultForUrl(prerenderManager, url);
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log(`Final Prerendered content for ${url}:`, prerenderResult.renderResultString);
|
||||||
|
})();
|
||||||
|
```
|
||||||
|
|
||||||
|
### Integrating with External Systems
|
||||||
|
|
||||||
|
`Corerender` can be integrated into broader systems that programmatically manage URLs and rendering frequencies. For instance, parsing and prerendering sitemaps:
|
||||||
|
|
||||||
|
```typescript
|
||||||
|
class IntegrationExample {
|
||||||
|
private prerenderManager: PrerenderManager;
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
this.prerenderManager = new PrerenderManager();
|
||||||
|
}
|
||||||
|
|
||||||
|
async prerenderFromSitemap(sitemapUrl: string) {
|
||||||
|
await this.prerenderManager.prerenderSitemap(sitemapUrl);
|
||||||
|
console.log('Finished prerendering sitemap:', sitemapUrl);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
(async () => {
|
||||||
|
const integrationExample = new IntegrationExample();
|
||||||
|
await integrationExample.prerenderFromSitemap('https://example.com/sitemap.xml');
|
||||||
|
})();
|
||||||
|
```
|
||||||
|
|
||||||
|
### Server-Side Rendering Directly with SmartSSR
|
||||||
|
|
||||||
|
`Rendertron` uses the highly efficient `smartssr` for SSR requests. You can easily direct incoming server requests to utilize this rendering pipeline:
|
||||||
|
|
||||||
|
```typescript
|
||||||
|
import { typedserver } from 'corerender/dist_ts/rendertron.plugins';
|
||||||
|
|
||||||
|
const serviceServerInstance = new typedserver.utilityservers.UtilityServiceServer({
|
||||||
|
serviceDomain: 'rendertron.example.com',
|
||||||
|
serviceName: 'RendertronService',
|
||||||
|
serviceVersion: '2.0.61', // Replace with dynamic version retrieval if needed
|
||||||
|
addCustomRoutes: async (serverArg) => {
|
||||||
|
serverArg.addRoute(
|
||||||
|
'/render/*',
|
||||||
|
new typedserver.servertools.Handler('GET', async (req, res) => {
|
||||||
|
const requestedUrl = req.url.replace('/render/', '');
|
||||||
|
const prerenderedContent = await prerenderManager.getPrerenderResultForUrl(requestedUrl);
|
||||||
|
res.write(prerenderedContent);
|
||||||
|
res.end();
|
||||||
|
})
|
||||||
|
);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
(async () => {
|
||||||
|
await serviceServerInstance.start();
|
||||||
|
console.log('SSR Server Started');
|
||||||
|
})();
|
||||||
|
```
|
||||||
|
|
||||||
|
### Customizing the Logger
|
||||||
|
|
||||||
|
`Rendertron` employs the `smartlog` package for logging activities across the service. To customize logging, instantiate a logger with custom configurations:
|
||||||
|
|
||||||
|
```typescript
|
||||||
|
import { smartlog } from 'corerender/dist_ts/rendertron.plugins';
|
||||||
|
|
||||||
|
const customLogger = smartlog.Smartlog.create({ /* custom options */ });
|
||||||
|
customLogger.log('info', 'Custom logger integrated successfully.');
|
||||||
|
```
|
||||||
|
|
||||||
|
### Closing Remarks
|
||||||
|
|
||||||
|
With these examples, you should have a robust understanding of how to implement `corerender` in your web application. It’s a powerful service that takes care of rendering optimizations, allowing developers to focus on building components and architecture, with clear workflows to handle tasks and results efficiently.
|
||||||
|
|
||||||
|
undefined
|
@ -2,7 +2,7 @@
|
|||||||
* autocreated commitinfo by @push.rocks/commitinfo
|
* autocreated commitinfo by @push.rocks/commitinfo
|
||||||
*/
|
*/
|
||||||
export const commitinfo = {
|
export const commitinfo = {
|
||||||
name: 'rendertron',
|
name: 'corerender',
|
||||||
version: '2.0.61',
|
version: '2.0.62',
|
||||||
description: 'a rendering service for lossless gmbh'
|
description: 'A rendering service designed for serve.zone that efficiently preserves styles while rendering web components.'
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user