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

noflo-passport

v0.0.1

Published

Wrapper around Passport.js

Downloads

4

Readme

Passport.js on NoFlo Build Status Dependency Status NPM version Stories in Ready

Authenticate your users with NoFlo! This is built on top of Passport.js for basic HTTP authentication with username/password, OpenID, OAuth, etc.

This package adheres to noflo-webserver convention of a request object:

{
  "req": <the request>
  "res": <the response>
}

NOTE: you MUST enable querystring by passing incoming requests through a webserver/Query for noflo-passport to work!

Installation

npm install --save noflo-passport

Usage

Listed in-ports in bold are required and out-ports in bold always produce IPs.

OAuthTwoStrategy

Implements OAuth 2.0 using passport-oauth strategy as outlined here. This component configures a provider for use.

Most of the ports accept configuration packets, most likely only once in the lifetime of the program. However, they may also be sent new configuration packets dynamically for situations like when the provider's authentication URLs are dependent upon the user's ID in their identity database.

The 'IN' in-port takes whatever you feed it and spits that out along with the tokens and profile upon every authentication. This is to provide a mechanism to identify a transaction when the provider does not return anything in the profile along with the tokens. The data it receives persists until new data is fed to it.

Because Passport.js requires a user object to be returned, there is a 'RETURN' in-port accepting the user object, the one sent by 'OUT' with a 'user' attribute. It then closes the connection by continuing with the HTTP request flow.

In-Ports

  • IN: IPs passed here will be forwarded as an array of IPs to OUT with the resulting tokens.
  • RETURN: Passport.js expects a user object to be passed to it when the token is consumed. For each OUT it must eventually return to RETURN to complete the transaction!
  • NAME: The name to assign an OAuth2 strategy with Passport.js. Pass this in last as this would perform the assignment.
  • ACCESS: The URL to request the access token. See "accessTokenURL" in Passport.js documentation
  • AUTH: The URL to authenticate the user. See "userAuthorizationURL" in Passport.js documentation
  • CALLBACK: The URL for the provider to call back. This should ultimately lead to an passport/OAuthTwoHandler process
  • KEY: The consumer key
  • SECRET: The consumer secret

Out-Ports

  • OUT: An object containing the IPs sent to 'IN', the access token, the refresh token, the profile, and the verify callback.

OAuthTwoHandler

This component handles incoming request in the OAuth handshake. it expects a request object, middleware-style. Attach this to a webserver/Server instance.

NOTE: you MUST enable querystring by passing incoming requests through a webserver/Query for noflo-passport to work!

In-Ports

  • IN: The request object
  • PROVIDER: The name of the provider to authenticate against
  • SESSION: Whether to enable session. Default to true
  • SCOPE: Specify OAuth2 scopes. Each IP is one scope.
  • SUCCESS: The URL to redirect upon success
  • FAILURE: The URL to redirect upon failure

Out-Ports

  • OUT: The request object