Coder Social home page Coder Social logo

authentify's Introduction

Authentify

Simple module to register users and login providing a User Storage.

The first thing we need to do is to implement our UserStorage, this is very easy:

import { UserStorage } from 'authentify';
import User from '../../models/user';

/**
 * This is an example of an implementation with MongoDB.
 * In this case we used a mongoose model.
 */
class MongoUserStorage extends UserStorage {
  findOne(criteria) {
    return User.findOne(criteria); //specific mongoose Implementation
  }

  create(attributes) {
    return User.create(attributes); //specific mongoose Implementation
  }
}

export default MongoUserStorage;

We extend the UserStorage class and implement both methods findOne & create. findOne should return a Promise which resolves to the user given a specific criteria (this will depend on your application). create should create a user and return a Promise which resolves to the user created.

After this you just use what the module expose which is (I'm going to use require here but we can use both, require or import, it depends on the ECMAScript our project is using):

  • UserStorage
// Just to extend it, this is basically a contract 'interface'
class MongoUserStorage extends (require('authentify').UserStorage)
  • Registerer
new (require('authentify').Registerer)()
      .setEmail(email)
      .setUsername(username)
      .setPassword(password)
      .setUserStorage(new MongoUserStorage())
      .register()
      .then(function(user) {})
      .catch(myCatchFunction);
  • Login
new (require('authentify').Login)()
      .setEmail(email)
      .setUsername(username)
      .setPassword(password)
      .setUserStorage(new MongoUserStorage())
      .authenticate()
      .then(function(user) {})
      .catch(myCatchFunction);

How To Handle errors

This module assumes that everything we are implementing in UserStorage is returning a Promise, that said every exception that could happen in the module will be thrown (literally, with throw) so you must make sure that you are using catch in your promises.

both Login and Registerer expose API to know when an error is an exception of that type, let's check an example:

import { Login } from 'authentify';

try {
// some login error happened here.
} catch(error) {
// this would normally be inside of a Promise.catch() and not a try-catch block.
  if (Login.isLoginException(error)) {
    // do something here.
  }
}

Login throws an UnauthorizedException which happens when the user provides wrong credentials. It also throws other exceptions but these are because of functionality extension through the Configurator, it can throw InvalidEmailException or InvalidPasswordException, Registerer also can.

For checking Registerer exceptions its exactly what you would expect: Register.isRegistererException().

Lastly Both Login and Registerer expose API to check each specific exception separately:

Login.isUnauthorizedException(e);
Registerer.isEmailAlreadyExistException(e);
Registerer.isUsernameAlreadyExistException(e);

// The Configurator exceptions which you must use through instances (they are not static methods in Login and Registerer).
// instance here could be either a Login or a Registerer object.

instance.isInvalidEmailException(e);
instance.isInvalidPasswordException(e);
instance.isUserStorageNotConfigureException(e);

How to run build

npm run build

How to run test

npm test

authentify's People

Contributors

jac1013 avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.