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 🙏

© 2024 – Pkg Stats / Ryan Hefner

serverless-scripts-plugin

v0.0.10

Published

Add scripts(nodejs) support to serverless 3.x

Downloads

84

Readme

What's the plugins for?

This plugin allows you to write scripts to customize Serverless behavior for Serverless 3.x

Features:

  • Run any command in any stage of serverless lifecycle
  • Add custom commands to serverless, e.g. npx serverless YOUR-COMMAND Example

Quick Start

  1. Install
    npm install --save-dev serverless-scripts-plugin
  2. Add to Serverless config
    plugins:
      - serverless-scripts-plugin
    
    custom:
      scripts:
        # set env vars for all hooks and commands
        env:
          EXTRA_VAR: VAR_VALUE       
    
        # add custom hooks
        hooks:
          before:package:createDeploymentArtifacts: npm run build
    
        # or custom commands
        commands:
          migrate: echo Running migration

Examples

1. Customize package behavior

The following config is using babel for transcompilation and packaging only the required folders: dist and node_modules without aws-sdk

```yml
plugins:
  - serverless-scripts-plugin

custom:
  scripts:
    hooks:
      before:package:createDeploymentArtifacts: npm run build

package:
  patterns:
    - '**/**'
    - '!dist/**'
    - '!node_modules/**'
    - node_modules/aws-sdk/**
```

2. Add a custom command

```yaml
plugins:
  - serverless-scripts-plugin

custom:
  scripts:
    hooks:
      before:migrate:command: echo before migrating
      after:migrate:command: echo after migrating
    commands:
      migrate: echo Running migration
```

Then you could run this command by:
```bash
$ npx serverless migrate
Running command: echo before migrating
before migrating
Running command: echo Running migrating
Running migrating
Running command: echo after migrating
after migrating
```

3. Deploy python function

```yml
plugins:
  - serverless-scripts-plugin

custom:
  scripts:
      hooks:
        before:package:createDeploymentArtifacts: ./package.sh

# serverless will use the specified package that generated by `./package.sh`
package:
  artifact: .serverless/package.zip
```

and package.sh script file to package the zip file (https://docs.aws.amazon.com/lambda/latest/dg/python-package.html)

```bash
  PACKAGE_FILE=.serverless/package.zip
  rm -f $PACKAGE_FILE && rm -rf output && mkdir -p output
  pip install -r requirements.txt --target output/libs
  # You can use the following command to install if you are using pipenv
  # pipenv requirements > output/requirements.txt && pip install -r output/requirements.txt --target output/libs
  (cd output/libs && zip -r ../../$PACKAGE_FILE . -x '*__pycache__*')
  (zip -r $PACKAGE_FILE your-src-folder -x '*__pycache__*')
```

Serverless would then deploy the zip file you built to aws lambda.

4. Run any command as a hook script

It's possible to run any command as the hook script, e.g. use the following command to zip the required folders

```yml
plugins:
  - serverless-scripts-plugin

custom:
  scripts:
    hooks:
      before:package:createDeploymentArtifacts: zip -q -r .serverless/package.zip src node_modules

service: service-name
package:
  artifact: .serverless/package.zip
```

5. Suppress console output

You could control what to show during running commands, in case there are sensitive info in command or console output.

```yml
custom:
  scripts:
    showStdoutOutput: false # Default true. true: output stderr to console, false: output nothing
    showStderrOutput: false # Default true. true: output stderr to console, false: output nothing
    showCommands: false # Default true. true: show the command before execute, false: do not show commands

    outputStream: stderr # Default combined. combined: forwards commands and scripts stderr and stdout to parent process stderr and stdout, stderr: forwards all logs to stderr, stdout: forwards all logs to stdout

    hooks:
      ...
    commands:
      ...
```

6. Add extra env vars for command / script

You can pass extra env variables for each command / script

custom:
  scripts:
    hooks:
      before:package:createDeploymentArtifacts:
       env: 
          LOCATION: .serverless
       scripts:
         - zip -q -r $LOCATION/package.zip src node_modules

7. Set current working directory for a command / script

It's possible to set current working directory for script execution

custom:
  scripts:
    hooks:
      before:package:createDeploymentArtifacts:
       cwd: very/very/very/very/very/long/path
       scripts:
         - zip -q -r package.zip src node_modules