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

diesel-engine

v0.2.8

Published

Workflow Engine for connecting tools

Downloads

6

Readme

Diesel (Slack Bot Workflow Engine)

Diesel aims to make slack bot development easy. Diesel's aim is to act as a flow engine separating view, state, and state progressions into a neat little package.

Concepts

A flow is a set of messages and actions that can start, end, or progress a flow. A progression is an instance of a particular flow. Flows need at least one message or one action

Messages are representations of Slack messages and interactive messages. Message representations are “rendered” statically, meaning, given the state of a progression and a triggering action if it exists, the message (JSON) can be built. Messages and message partials should be componentidzed and templitized. You should be able to build a “view” of a message that can have multiple versions depending on the state like someone clicking an “approve” button. And you should be able to dynamically inject things like who approved it.

Actions are Slack events (events api) slack interactive components (buttons, dialogs, message menu loads), slash commands, or something custom. Action Handlers can handle one or more types of actions and mutate the state, and then progress a progression to one or more messages.

A flow should be package able and call-able as a “sub-flow”. Multiple sub-flows can be triggered and brought back together (with “and” and “or” like behavior).

Action Handlers

Handlers accept an action and a state (think redux) and mutate the state returning it or a promise for one. Progressions can take multiple action handlers per event like middleware

TO_DO:

  • [ ] How do you handle errors? Remediation step?
  • [ ] Is it worth checking if a state transition is valid?