Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@f5devcentral/f5-fast-core

Package Overview
Dependencies
Maintainers
12
Versions
27
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@f5devcentral/f5-fast-core

The core module for F5 Application Services Templates

  • 0.5.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
178
decreased by-13.17%
Maintainers
12
Weekly downloads
 
Created
Source

Pipeline npm NPM

F5 Application Services Templates (FAST) SDK

This module provides a framework for handling templates.

Features

  • Parses Mustache templates and an extended template format (in YAML)
  • Generates a view schema from parsed template data
  • Supports Mustache partials and sections
  • Renders templates with user-provided views
  • Validates user-provided views against generated view schema
  • Includes a command line interface

Installation

To install this module run:

npm install @f5devcentral/f5-fast-core

Usage

CLI

A command line interface is provided via a fast binary. The help text is provided below and also accessed via fast --help:

fast <command>

Commands:
  fast validate <file>                                validate given template source file
  fast schema <file>                                  get template parameter schema for given template source file
  fast validateParameters <tmplFile> <parameterFile>  validate supplied template parameters with given template
  fast render <tmplFile> [parameterFile]              render given template file with supplied parameters
  fast validateTemplateSet <templateSetPath>          validate supplied template set
  fast htmlpreview <tmplFile> [parameterFile]         generate a static HTML file with a preview editor to standard out
  fast packageTemplateSet <templateSetPath> [dst]     build a package for a given template set

Options:
  --help     Show help                                                                                         [boolean]
  --version  Show version number                                                                               [boolean]

For more information on a given command use the --help flag combined with a command:

fast <command> --help

The CLI can also be accessed by executing cli.js. For example:

./cli.js render path/to/template

Module

Below is a basic example for loading a template without any additional type schema:

const fast = require('@f5devcentral/f5-fast-core');

const ymldata = `
    view:
      message: Hello!
    definitions:
      body:
        template:
          <body>
            <h1>{{message}}</h1>
          </body>
    template: |
      <html>
        {{> body}}
      </html>
`;

fast.Template.loadYaml(ymldata)
    .then((template) => {
        console.log(template.getParametersSchema());
        console.log(template.render({message: "Hello world!"}));
    });

In addition to Template.loadYaml(), a Template can be created from Mustache data using Template.loadMst():

const fast = require('@f5devcentral/f5-fast-core');

const mstdata = '{{message}}';

fast.Template.loadMst(ymldata)
    .then((template) => {
        console.log(template.getParametersSchema());
        console.log(template.render({message: "Hello world!"}));
    });

To support user-defined types, a SchemaProvider must be used. The FsSchemaProvider can be used to load schema from disk:

const fast = require('@f5devcentral/f5-fast-core');

const templatesPath = '/path/to/templatesdir'; // directory containing types.json
const schemaProvider = new fast.FsSchemaProvider(templatesPath);
const mstdata = '{{virtual_port:types:port}}';

fast.Template.loadMst(mstdata, schemaProvider)
    .then((template) => {
        console.log(template.getParametersSchema());
        console.log(template.render({virtual_port: 443});
    });

A higher-level API is available for loading templates via TemplateProvider classes. These classes will handle calling the correct load function (Template.loadYaml() vs Template.loadMst()) and can also handle schemas. For example, to load "templates sets" (a collection of template source files) from a given directory, the FsTemplateProvider class can be used:

const fast = require('@f5devcentral/f5-fast-core');

const templatesPath = '/path/to/templatesdir';
const templateProvider = new fast.FsTemplateProvider(templatesPath);

templateProvider.fetch('templateSetName/templateName')
    .then((template) => {
        console.log(template.getParametersSchema());
        console.log(template.render({
            var: "value",
            boolVar: false
        }));
    });

Development

npm commands should be run in the core subdirectory, not at the top-level.

  • To check for lint errors run npm run lint
  • To run unit tests use npm test

Both of these are run as part of the CI pipeline for this repo.

Documentation

For more information about FAST, see FAST Documentation

License

Apache License 2.0

Copyright 2014-2020 F5 Networks Inc.

F5 Networks Contributor License Agreement

Before you start contributing to any project sponsored by F5 Networks, Inc. (F5) on GitHub, you will need to sign a Contributor License Agreement (CLA).

If you are signing as an individual, we recommend that you talk to your employer (if applicable) before signing the CLA since some employment agreements may have restrictions on your contributions to other projects. Otherwise by submitting a CLA you represent that you are legally entitled to grant the licenses recited therein.

If your employer has rights to intellectual property that you create, such as your contributions, you represent that you have received permission to make contributions on behalf of that employer, that your employer has waived such rights for your contributions, or that your employer has executed a separate CLA with F5.

If you are signing on behalf of a company, you represent that you are legally entitled to grant the license recited therein. You represent further that each employee of the entity that submits contributions is authorized to submit such contributions on behalf of the entity pursuant to the CLA.

Keywords

FAQs

Package last updated on 27 May 2020

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc