npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

location-aware-hybrid-cloud

v1.1.1

Published

babel plugin for hybrid local and cloud deployment

Downloads

20

Readme

Location-Aware-Hybrid-Cloud

The project can be found on npm.org Location Aware Hybrid Cloud. run npm install location-aware-hybrid-cloud --save to install through npm manager.

Vision and Goals Of The Project:

Some interesting large datasets reside in public cloud providers, such as Google Cloud Services (GCS) and Amazon Web Services (AWS). However, a company may desire certain calculations and information to only reside in its private cloud. Moving large amounts of data from the public cloud to the private cloud is expensive and time consuming. This project aims to build a toolkit that achieves computational locality by using a combination “Function as a Service” (FaaS) and containers. In this way, preliminary calculations and queries can be implemented in a public cloud, and then the intermediate result can be transferred back to private cloud. High-level goals of this project include:

  • Enabling computational locality via FaaS: This application will transpile the input functions so as to call its equivalent cloud functions in different cloud.
  • Reducing development lifecycle: With this project, components in different clouds could be considered and integrated as a single application, therefore reducing the development complexity.

Users Of The Project:

This project would be used by companies and research teams that have multiple applications or computational modules in different clouds. Examples include investment banks, hedge funds, or tech companies driven by concerns for safety, privacy, or amount of computation. A simple demo program:

Project Setup

Write your JS file in normal way and add comments to deploy on cloud. Detail of the comments can be found below.

For running on AWS Lambda

You need to have an AWS account and save the root access key in .aws folder. Detail information can be see Getting starts with AWS. The provider is aws and only augrement supported now is regions to be deployed in aws.

/* @cloud 
Provider:aws
S3:true
Region: us-east-2
*/

For running on Google Cloud Function

You need to have an Google Cloud Service account, create corresponding project first on the Google Cloud Console, and get the credential key files. More can be see at the github project Go through the Setup Google Cloud Part to setup before deployment. The provider is gcf as google cloud function and passing arguements includes the region that is supposed to deploy, projectId which is created in google cloud console and path for the credential key file.

/* @cloud 
Provider: goog
Region: us-central1
Project: testgfc-164121
Credentions: /Users/star/.gcloud/testgfc-bcc6039af0aa.json
*/

How to run the project

Put the JS code in src\files\main.js

Old Way:

  • Step 1: sudo npm install -g install node module dependencies globally
  • Step 2: npm run build genereate es5, node.js compatible file. The result files are in dist folder.
  • Step 4: npm run deploy to deploy the cloud functions to the clouds
  • Step 5: npm run start to run the application

New Way:

  • Step 1: sudo npm install -g (install node module dependencies)
  • Step 2: npm run lahc (genereate es5, node.js compatible file, deploy, and run)

Project Structure:

Alt text

The executor has four modes:

  1. extract-cloud: to extract cloud function from customer js file, and build a serverless.yml file for each function.
  2. deploy-cloud: to deploy the extracted cloud function on to AWS Lambda through serverless
  3. prepare-local: it will get back the uri of cloud function from AWS and generate a local.js file with request to AWS.
  4. live: run through all the above command in one mode Finally, run "node local.js" or "npm run start" to execute the functions.

Setting up babel environment:

  1. Install node

  2. Create package.json https://docs.npmjs.com/getting-started/using-a-package.json

  3. Install babel https://babeljs.io/docs/setup/#installation (Ex $ npm install babel-core babel-cli) https://www.youtube.com/watch?v=sZ0z7B7QmjI https://github.com/bradtraversy/youtube_es2015_source/tree/master/01_babel

  4. $ cd src

  5. $ npm run build

How to contribute

The project has two parts with Babel transpile and serverless deployment. Babel transpile files are in the src folder as index.js executor.js and parser.js

  1. index.js is the start of program and defines the input directory output directory and running mode. Modify the bellow to change default setting. Example command node index.js -m live -i input -d output
var yargOptions = {
	mode: {
		alias: 'm',
		describe: 'Mode in which to run the CLI',
		default: 'extract-cloud',
		demand: true,
		choices: ['extract-cloud', 'deploy-cloud', 'prepare-local', 'live'],
		type: 'string'
	},
	'input-dir': {
		alias: 'i',
		default: './files',
		describe: 'Root directory containing the code to be parsed and deployed',
		demand: true,
		type: 'string'
	},
	'output-dir': {
		alias: 'd',
		default: './cloud',
		describe: 'Target directory where the CLI outputs all the runnable files',
		demand: true,
		type: 'string'
	}
};
  1. executor.js defines all the modes and execution of different modes
  • extract cloud will execute the parser.js and extract cloud function to dist/cloud/ folder. Each cloud function has its own folder function.js and serverless.yml file. All the setting of serverless.yml can be accessed there.
  • deploy cloud will deploy all the functions to there cloud respectively.
  • prepare local will get back the deployment url and prepare the local.js file in dist/files. local.js is file with http request to the cloud provider for cloud functions.
  1. parser.js is the acctural execution of Babel. Only AWS and GCF are supported now.

Example Express JS file

The src/main.js shows an example expressjs app with webpage in view folder. Update the local file path in main.js in order to run the applicaion. The application has two cloud function. One is deployed and runs on AWS Lambda, the other runs on Google Cloud Function. Click the button to see the result from each cloud function.