Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
SaxonJS is an XSLT 3.0 processor written mainly in JavaScript, and partly in XSLT. SaxonJS 2 is available for two JavaScript environments: the browser, and Node.js. We'll focus here on Node.js.
The npm package saxon-js provides a JavaScript API that allows you to:
A command-line interface for XSLT 3.0 transformation is provided in a separate package, xslt3.
Full documentation is available, delivered using SaxonJS 2 running in your browser.
XSLT 3.0 and XPath 3.1 are the latest versions of the XSLT and XPath specifications from W3C.
The 1.0 versions of these languages are widely known and widely used, but they are now twenty years old, and the standards have come a long way since then.
Version 2 of the specs introduced, among other things:
<xsl:for-each-group>
)Version 3 added:
<p>Written by {@author} on {@date}</p>
SaxonJS implements all of the mandatory parts of the XSLT 3.0 and XPath 3.1 specifications, and most of the optional parts. The only major things it leaves out are:
The Saxon product effectively contains a compile time and a run time component. The compiler takes XSLT source code as input, and generates a Stylesheet Export File (SEF), which is an intermediate representation of the compiled and optimized stylesheet in a custom JSON format. In fact, Saxonica offers two XSLT compilers:
SaxonJS will load SEF files generated by either compiler. For production work the XJ compiler is a better choice: it is faster, it produces better diagnostics, it generates smaller and faster run-time code, and it has fewer restrictions. But the XX compiler is available at no cost.
XSLT 3.0 packages are partially supported: SaxonJS offers run-time support, but to compile them you will need the XJ compiler.
SaxonJS is developed by Saxonica, a company created in 2004 by Michael Kay, who was the editor of the XSLT 2.0 and 3.0 specifications in W3C. The original Saxon product on the Java platform has been continually developed for over 20 years, and has acquired a reputation for standards conformance, performance, and reliability.
SaxonJS takes many of the successful design ideas of the original Java-based product and re-implements them in JavaScript. Although the Node.js version of the product is brand new, it benefits not only from the experience of the team creating it, but also from the existence of a vast test suite, ensuring a high level of reliability.
To compile a stylesheet held in books.xsl
to a SEF file in books.sef.json
, to be run either in the browser or Node.js, use the command line:
xslt3 -xsl:books.xsl -export:books.sef.json -t -ns:##html5
Here -t
requests progress messages on the console, and -ns:##html5
requests customized handling of namespaces in the HTML DOM (which is non-standard according to the W3C standards, but mimics the way XSLT 1.0 processors behave in the browser).
To execute the stylesheet against a source document books.xml
and write the output to a file books.html
, use:
xslt3 -xsl:books.sef.json -s:books.xml -o:books.html -t
Alternatively the XSLT stylesheet can be run directly against the source document, using:
xslt3 -xsl:books.xsl -s:books.xml -o:books.html -t
To run the same transformation from JavaScript within a Node.js application, sending the result to an HTTP response object response
, use:
SaxonJS.transform({
stylesheetFileName: "books.sef.json",
sourceFileName: "books.xml",
destination: "serialized"
}, "async")
.then (output => {
response.writeHead(200, {'Content-Type': 'text/html'});
response.write(output.principalResult);
response.end();
})
The following example parses an XML document, executes a simple XPath expression, and serializes the result:
SaxonJS.getResource({
location: '../../src/test.xml',
type: "xml"
}).then(doc => {
const result = SaxonJS.XPath.evaluate("//test[@id='abc']", doc);
const output = SaxonJS.serialize(result, {method: "xml", indent: true, "omit-xml-declaration":true});
console.log(output);
})
The next example does the same with JSON input:
SaxonJS.getResource({
location: '../../src/test.json',
type: "json"
}).then(doc => {
const result = SaxonJS.XPath.evaluate("?cities?*[?name='Berlin']", doc);
const output = SaxonJS.serialize(result, {method: "json", indent: true});
console.log(output);
})
SaxonJS for Node.js includes the following deliverables, available free of charge (but the license is not open source):
saxon-js package (SaxonJS2N.js): this includes all the code needed to compile and execute XSLT 3.0 stylesheets under Node.js, including an API enabling applications to invoke stylesheet execution. The JavaScript module is around 3.7Mb in size.
xslt3 package (xslt3.js): this small module provides a command line interface, allowing XSLT 3.0 transformations to be compiled and run from a terminal/console. It makes use of the services provided by the saxon-js (SaxonJS2N.js) package.
SaxonJS is also available to run in the browser, with innovative extensions allowing user interaction to be handled entirely from declarative XSLT code, without any need for low level Javascript event handling. For details, see the Saxonica web site.
SaxonJS is offered free of charge, but for serious users, a chargeable service package is available for an annual fee. The service package includes access to source code and build tools, debugging aids, and other resources such as tutorials and add-on utilities that may be published from time to time. For details, see the Saxonica web site.
All users are welcome to use the public support site for reporting issues and seeking help (registration required). In addition, many questions are asked and answered on StackOverflow: please use the saxon-js tag.
FAQs
SaxonJS XSLT 3.0 processor: command line interface to SaxonJS
We found that xslt3 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
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.