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

@travetto/boot

Package Overview
Dependencies
Maintainers
1
Versions
76
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@travetto/boot

Bootstrapping and common utilities for travetto applications.

  • 1.0.2
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
4
increased by33.33%
Maintainers
1
Weekly downloads
 
Created
Source

const { doc: d, Code, Section, List, inp, meth, Ref, lib, Execute } = require('@travetto/doc'); const { FileCache, ExecUtil, StreamUtil } = require('./src');

const AppCacheLink = Ref('AppCache', './src-ts/app-cache.ts'); const FileCacheLink = Ref(FileCache.name, './src-ts/cache.ts'); const FsUtilLink = Ref('FsUtil', './src-ts/fs.ts'); const ScanFsLink = Ref('ScanFs', './src-ts/scan.ts'); const ExecUtilLink = Ref(ExecUtil.name, './src-ts/exec.ts'); const StreamUtilLink = Ref(StreamUtil.name, './src-ts/stream.ts');

exports.text = d` Boot is basic environment awareness coupled with typescript bootstrapping for ${lib.Travetto} apps and libraries. It has support for the following key areas: ${List( 'Environmental Information', 'Cache Support', 'File Operations', 'Typescript bootstrapping', 'Process execution', 'Stream Support' )}

${Section('Environmental Information')} The functionality we support for testing and retrieving environment information: ${List( d${methisTrue(key: string): boolean;} - Test whether or not an environment flag is set and is true, d${methisFalse(key: string): boolean;} - Test whether or not an environment flag is set and is false, d${methisSet(key:string): boolean;} - Test whether or not an environment value is set (excludes: ${inpnull}, ${inp''}, and ${inpundefined}), d${methget(key: string, def?: string): string;} - Retrieve an environmental value with a potential default, d${methgetInt(key: string, def?: number): number;} - Retrieve an environmental value as a number, d${methgetList(key: string): string[];} - Retrieve an environmental value as a list, d${methgetTime(key: string, def: number):number} - Reads an environment variable as milliseconds, with support for ${inps}, ${inpm}, and ${inph} suffixes to provide succinct time units. )}

${Section('File Cache')} The framework uses a file cache to support it's compilation activities for performance. This cache is also leveraged by other modules to support storing of complex calculations. ${AppCacheLink} is the cache that is used specific to the framework, and is an instance of ${FileCacheLink}. ${FileCacheLink} is the generic structure for supporting a file cache that invalidates on modification/creation changes.

The class organization looks like:

${Code('File Cache Structure', './src/cache.d.ts')}

Everything is based on absolute paths being passed in, and translated into cache specific files.

${Section('Registration')} This functionality allows the program to opt in the typescript compiler. This allows for run-time compilation of typescript files.

${Section('File System Interaction')} ${FsUtilLink} provides some high level functionality (like recursive directory delete).

${Section('File System Scanning')} ${ScanFsLink} provides a breadth-first search through the file system with the ability to track and collect files via patterns.

${Section('Process Execution')} Just like ${lib.ChildProcess}, the ${ExecUtilLink} exposes ${methspawn} and ${methfork}. These are generally wrappers around the underlying functionality. In addition to the base functionality, each of those functions is converted to a ${inpPromise} structure, that throws an error on an non-zero return status.

A simple example would be:

${Code('Running a directory listing via ls', 'alt/docs/src/exec.ts')}

As you can see, the call returns not only the child process information, but the ${inpPromise} to wait for. Additionally, some common patterns are provided for the default construction of the child process. In addition to the standard options for running child processes, the module also supports:

${List( d${inptimeout} as the number of milliseconds the process can run before terminating and throwing an error, d${inpquiet} which suppresses all stdout/stderr output, d${inpstdin} as a string, buffer or stream to provide input to the program you are running;, d${inptimeoutKill} allows for registering functionality to execute when a process is force killed by timeout )}

${Section('Stream Support')} The ${StreamUtilLink} class provides basic stream utilities for use within the framework:

${List( d${methtoBuffer(src: Readable | Buffer | string): Promise} for converting a stream/buffer/filepath to a Buffer., d${methtoReadable(src: Readable | Buffer | string):Promise} for converting a stream/buffer/filepath to a Readable, d${methwriteToFile(src: Readable, out: string):Promise} will stream a readable into a file path, and wait for completion., d${methwaitForCompletion(src: Readable, finish:()=>Promise)} will ensure the stream remains open until the promise finish produces is satisfied., )}

${Section('CLI - clean')}

The module provides the ability to clear the compilation cache to handle any inconsistencies that may arise.

${Execute('Clean operation', 'travetto', ['clean', '--help'])} `;

Keywords

FAQs

Package last updated on 06 Jul 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