s-id
Simple Accounts system for Meteor.
This is a simple and custom Accounts system with config file. It is not dependant on routing, but there are examples how to configure your routes with Iron Router and Flow Router. You can configure your alerts/messages, validators and callback functions.
Demo
(With minimal styling, but you can do this very simple by adding your own css classes)
Website:
Blog post about it
Meteor Accounts based on sId package
Usage example in Scotty boilerplate
Usage
Just add the package:
meteor add juliancwirko:s-id
Full Config (all is optional and here you can overwrite defaults)
Place it somewhere where it will be accessible by Server and Client
1Meteor.startup(function () { 2 sId.config({ 3 registerForm: { 4 mainClass: 's-id-register-form', // css class for main container - you can change it and style it like you want in your app 5 title: 'Register', // form title 6 leadText: 'Hi, join us!', // form description text 7 submitBtnLabel: 'Register' // button label text 8 }, 9 loginForm: { 10 mainClass: 's-id-login-form', 11 title: 'Login', 12 leadText: 'Beam me up, Scotty!', 13 submitBtnLabel: 'Login' 14 }, 15 forgotPassForm: { 16 mainClass: 's-id-forgot-password-form', 17 title: 'Forgot Password', 18 leadText: 'Please fill in email address!', 19 submitBtnLabel: 'Send New!' 20 }, 21 resetPassForm: { 22 mainClass: 's-id-reset-password-form', 23 title: 'Reset Password', 24 leadText: 'Please fill in new password!', 25 submitBtnLabel: 'Set New!' 26 }, 27 socialButtons: { // disable/enable social login/register buttons 28 'github': true, 29 'google': true, 30 'twitter': true, 31 'facebook': true, 32 'labels': { // labels for social buttons 33 'github': 'GitHub Access', 34 'google': 'Google Access', 35 'twitter': 'Twitter Access', 36 'facebook': 'Facebook Access' 37 } 38 }, 39 // turn on e-mail verification.. without it user is still able to login, you can block it in the app by 40 // checking e-mail verified field 41 emailVerification: true, 42 // change it to 'true' if you need only e-mail field on register form (default there is username and e-mail) 43 registerEmailFieldOnly: false, 44 // you can turn on and off autologin after user creation - in default turned on 45 autoLoginAfterRegistration: true, 46 // you can pass empty messages object to turn it off 47 messages: { 48 verifyEmail: 'Verify your e-mail address', 49 verifiedEmail: 'Your email address was verified. Thanks!', 50 somethingWrong: 'Something went wrong! Here is the error message: ', 51 fillAllFields: 'Fill in all fields!', 52 loginNow: 'You can login now.', 53 sending: 'Sending...', 54 validEmail: 'E-mail should be a valid e-mail address!', 55 validPassword: 'Password should be at least one number, one lowercase and one uppercase letter and at least six characters!', 56 validUsername: 'Username should be at least 3 characters long and max 12 characters!', 57 // placeholders 58 loginNamePlaceholderEmailOnly: 'E-mail', 59 loginNamePlaceholder: 'Username or E-mail', 60 usernamePlaceholder: 'Username', 61 passwordPlaceholder: 'Password', 62 emailPlaceholder: 'E-mail', 63 newPasswordPlaceholder: 'New password' 64 }, 65 // should return true or false - you can overwrite these functions in your app sId config... 66 // also remember to adjust your error messages (config above) 67 validateUsername: function (username) { 68 var min = 3; 69 var max = 12; 70 if (username && username.length >= min && username.length <= max) { 71 return true; 72 } 73 return false; 74 }, 75 validatePassword: function (password) { 76 var r = /(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{6,}/; 77 if (password && r.test(password)) { 78 return true; 79 } 80 return false; 81 }, 82 validateEmail: function (email) { 83 var r = /^(([^<>()[\]\.,;:\s@\"]+(\.[^<>()[\]\.,;:\s@\"]+)*)|(\".+\"))@(([^<>()[\]\.,;:\s@\"]+\.)+[^<>()[\]\.,;:\s@\"]{2,})$/i; 84 if (r.test(email)) { 85 return true; 86 } 87 return false; 88 }, 89 onLogged: function () { 90 // callback after successful login 91 // it could be for example Router.go('/') or FlowRouter.go('/dashboard') or any other 92 }, 93 onRegistered: function () { 94 // callback after successful registration 95 }, 96 onForgotPassword: function () { 97 // callback after successful on forgot password action 98 }, 99 onResetPassword: function () { 100 // callback after successful password reset 101 }, 102 getPasswordResetToken: function () { 103 // here you should return reset password tokent from your route param 104 // you should have configured route: '/reset-password/:resetToken', 105 // then with Iron Router you can do something like: 106 // 107 // With Iron Router 108 // return Router.current().params.resetToken; or with Flow Router 109 // or with Flow Router 110 // return FlowRouter.getParam('resetToken'); 111 } 112 }); 113});
You can configure/overwrite here validator functions and messages strings. If you want to remove username, password or e-mail validation just 'return true' in a particular validator function.
You can configure your routes for each view if you want. You can use Iron Router or Flow Router it is up to you because here you will get only templates and couple of config functions which will alow you to configure your login, register callbacks. Below you will find some examples for Iron Router and Flow Router. Templates to use are:
- sIdLoginView
- sIdRegisterView
- sIdForgotPasswordView
- sIdResetPasswordView
Example routes which you can use in your app (Iron Router example)
Routes names are important here.
1Router.map(function() { 2 this.route('sIdLoginView', { 3 path: '/login', 4 }); 5 this.route('sIdRegisterView', { 6 path: '/register' 7 }); 8 this.route('sIdForgotPasswordView', { 9 path: '/forgot-password' 10 }); 11 this.route('sIdResetPasswordView', { 12 path: '/reset-password/:resetToken' 13 }); 14});
Example routes which you can use in your app (Flow Router and Blaze Layout example)
1FlowRouter.route('/login', { 2 name: 'sIdLoginView', 3 action: function () { 4 BlazeLayout.render('layout', {main: 'sIdLoginView'}); 5 } 6}); 7FlowRouter.route('/register', { 8 name: 'sIdRegisterView', 9 action: function () { 10 BlazeLayout.render('layout', {main: 'sIdRegisterView'}); 11 } 12}); 13FlowRouter.route('/forgot-password', { 14 name: 'sIdForgotPasswordView', 15 action: function () { 16 BlazeLayout.render('layout', {main: 'sIdForgotPasswordView'}); 17 } 18}); 19FlowRouter.route('/reset-password', { 20 name: 'sIdResetPasswordView', 21 action: function () { 22 BlazeLayout.render('layout', {main: 'sIdResetPasswordView'}); 23 } 24});
Basicaly you just use ready to go templates from the package and some callbacks which you can configure.
You can then use (somewhere in your templates):
1{{#if currentUser}} 2 <a href="#" class="js-logout">Logout</a></li> 3{{else}} 4 <a href="/login">Login</a> 5 <a href="/register">Register</a> 6{{/if}}
Logout event by Meteor.logout(function () { console.log('logged out!') }) - see docs.meteor.com
Log the user in using an external service
You can log/sign in using an external service. For now it is GitHub, Google, Twitter
If you want to use social buttons (enabled by default) You have to setup your settings.json file : Meteor Docs
Example (settings.json in your app root folder):
{ "private": { "github": { "clientId": "{your github API client id here}", "secret": "{your google API secret key here}" }, "google": { "clientId": "{your google API client id here}", "secret": "{your google API secret key here}" }, "twitter": { "consumerKey": "{your twitter API customer key here}", "secret": "{your twitter API secret key here}" }, "facebook": { "appId": "{your facebook API app id here}", "secret": "{your facebook API secret key here}" } } }
You can generate your API keys on these sites:
Then you should run your app with:
meteor --settings settings.json
You will find more in Meteor Docs.
Be carefull with Twitter - the email of logged in user isn't avaible
User data transformation on user creation
If you want to transform data in your user collection you can use Accounts.onCreateUser
Example:
1Accounts.onCreateUser(function (options, user) { 2 if (user.services.github) { 3 4 user.username = user.services.github.username; 5 user.emails = []; 6 user.emails.push({ 7 address: user.services.github.email, 8 verified: true 9 }); 10 11 return user; 12 } 13 14 if (user.services.google) { 15 16 user.username = user.services.google.email; 17 user.emails = []; 18 user.emails.push({ 19 address: user.services.google.email, 20 verified: true 21 }); 22 23 return user; 24 } 25 26 if (user.services.facebook) { 27 28 user.username = user.services.facebook.email; 29 user.emails = []; 30 user.emails.push({ 31 address: user.services.facebook.email, 32 verified: true 33 }); 34 35 return user; 36 } 37 38 if (user.services.twitter) { 39 40 user.username = user.services.twitter.screenName; 41 return user; 42 43 } 44 45 return user; 46});
Form Validation Alerts
This package uses another Meteor package called juliancwirko:s-alert
. You don't need to install it, but you might want to see how to configure it. You'll find the documentation here: s-alert.meteorapp.com.
If you don't want to configure it just place {{> sAlert}}
template in your main template in the app.
Styling
There will be more customization in the future. For now you can use mainClass
(sId config) as a namespace for DOM elements which has its own ids and classes. As you can see if you provide your own css class in the config you will get simple unstyled template.
You can take the package style.css file as a reference.
It is also integrated with s-alert notifications
If you want you can play with excelent package for overwriting templates: aldeed:template-extension
Sending Emails
You can configure Mailgun with Meteor.
Example:
1Meteor.startup(function () { 2 process.env.MAIL_URL = 'smtp://postmaster@{your-data}.mailgun.org:{your-data}@smtp.mailgun.org:587'; 3});
Apps using it:
Let me know if you want you app listed here ;)
Changelog
- v3.2.1 - login username e-mail type #5
- v3.2.0 - changed default styles
- v3.1.2 - v3.1.3 new option
autoLoginAfterRegistration
#4 - v3.1.1 small improvements
- v3.1.0 registerEmailFieldOnly option see: #3
- v3.0.2 versions bump
- v3.0.1 versions bump
- v3.0.0 added email verification option, added messages config, added validators config, docs changes
- v2.0.0 added Facebook service (thanks to @yankeyhotel), settings.json structure changed (see example above)
- v1.0.2 fix forgot password link usage
- v1.0.1 fix onLogged() callback with external services like Google etc.
- v1.0.0 is not depended on Iron Router anymore. You should use templates and make your own routes (example above). You can use onLogged, onRegistered, onForgotPassword, onResetPassword callbacks in config to make (for example) redirections.