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

kaede

v0.3.1

Published

A light-weighted LINE bot platform

Downloads

5

Readme

Kaede

A light-weighted LINE bot platform :maple_leaf:

Requirements

Node.js 8 or higher

Install

Via npm:

npm i -g kaede

How to use

Kaede is under heavy development and the hehaviour can be changed at any time.

$ kaede [args] <script>
kaede bot.js

# with custom config path (kaede.config.json by default)
kaede --config custom.config.json bot.js

# show help
kaede --help

The bot script should default-export an async generator yielding message objects.

export default async function* (event) {
  yield { type: 'text', text: 'hello' };
  yield { type: 'text', text: 'world' };
}

You can also refer to the bot context as the 2nd argument.

export default async function* (event, ctx) {
  const profile = await ctx.client.getProfile(event.source.userId);
  yield { type: 'text', text: `hello, ${profile.displayName}!` };
}

The context object has a type like below.

{
  client: Client, // Messaging API Client
  baseUrl: string, // base URL of webhook server
  staticRoot: string, // absolute path to static root directory
}

About the interface of Client, please refer to the documentation of line-bot-sdk-nodejs.

The kaede command with a bot script path will automatically set up a webhook server and a ngrok tunnel. Please set the generated URL as a webhook URL in LINE Developers Console. The URL will already have been copied to the system clipboard.

$ kaede bot.js
Listening at 91178db2.ngrok.io
91178db2.ngrok.io is copied to the clipboard

Press Enter/Return to reload the bot script
Press Ctrl+C/D to quit

For detailed usages, please refer to the examples.

Static file serving

Kaede serves static files in static/ by default. You can also set this with --static in CLI. Please refer to the context for webhook base URL and static root.

`${ctx.baseUrl}/images/some_image.jpg`
// => will serve a file at `${ctx.staticRoot}/images/some_image.jpg`

Features

  • [x] Basic webhook functionality
  • [x] ngrok integration
  • [x] Hot reload for bot script
  • [ ] Connect adaptor for production usage

License

Apache License Version 2.0