1.0.2 • Published 7 years ago

authentify v1.0.2

Weekly downloads
1
License
MIT
Repository
-
Last release
7 years ago

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

1.0.2

7 years ago

1.0.1

7 years ago

1.0.0

7 years ago

0.1.0

7 years ago

0.0.1

7 years ago