Passwords
The accounts-password package contains a full system for password-based authentication. In addition to the basic username and password-based sign-in process, it also supports email-based sign-in including address verification and password recovery emails.
The Meteor server stores passwords using the bcrypt algorithm. This helps protect against embarrassing password leaks if the server’s database is compromised.
To add password support to your application, run this command in your terminal:
meteor add accounts-password
You can construct your own user interface using the functions below, or use the accounts-ui package to include a turn-key user interface for password-based sign-in.
Anywhere Accounts.createUser(options, [callback]) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_client.js, line 115)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_client.js, line 115) Create a new user.
Arguments
-
callbackFunction -
Client only, optional callback. Called with no arguments on success, or with a single
Errorargument on failure.
Options
-
usernameString -
A unique name for this user.
-
emailString -
The user's email address.
-
passwordString -
The user's password. This is not sent in plain text over the wire.
-
profileObject -
The user's profile, typically including the
namefield.
On the client, this function logs in as the newly created user on successful completion. On the server, it returns the newly created user id.
On the client, you must pass password and at least one of username or email — enough information for the user to be able to log in again later. If there are existing users with a username or email only differing in case, createUser will fail. The callback’s error.reason will be 'Username already exists.' or 'Email already exists.' In the latter case, the user can then either login or reset their password.
On the server, you do not need to specify password, but the user will not be able to log in until it has a password (eg, set with Accounts.setPassword). To create an account without a password on the server and still let the user pick their own password, call createUser with the email option and then call Accounts.sendEnrollmentEmail. This will send the user an email with a link to set their initial password.
By default the profile option is added directly to the new user document. To override this behavior, use Accounts.onCreateUser.
This function is only used for creating users with passwords. The external service login flows do not use this function.
Instead of modifying documents in the Meteor.users collection directly, use these convenience functions which correctly check for case insensitive duplicates before updates.
Server Accounts.setUsername(userId, newUsername) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 375)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 375) Change a user's username. Use this instead of updating the database directly. The operation will fail if there is an existing user with a username only differing in case.
Arguments
-
userIdString -
The ID of the user to update.
-
newUsernameString -
A new username for the user.
Server Accounts.addEmail(userId, newEmail, [verified]) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 864)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 864) Add an email address for a user. Use this instead of directly updating the database. The operation will fail if there is a different user with an email only differing in case. If the specified user has an existing email only differing in case however, we replace it.
Arguments
-
userIdString -
The ID of the user to update.
-
newEmailString -
A new email address for the user.
-
verifiedBoolean -
Optional - whether the new email address should be marked as verified. Defaults to false.
By default, an email address is added with { verified: false }. Use Accounts.sendVerificationEmail to send an email with a link the user can use to verify their email address.
Server Accounts.removeEmail(userId, email) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 948)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 948) Remove an email address for a user. Use this instead of updating the database directly.
Arguments
-
userIdString -
The ID of the user to update.
-
emailString -
The email address to remove.
Client Accounts.verifyEmail(token, [callback]) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_client.js, line 263)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_client.js, line 263) Marks the user's email address as verified. Logs the user in afterwards.
Arguments
-
tokenString -
The token retrieved from the verification URL.
-
callbackFunction -
Optional callback. Called with no arguments on success, or with a single
Errorargument on failure.
This function accepts tokens passed into the callback registered with Accounts.onEmailVerificationLink.
Server Accounts.findUserByUsername(username) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 124)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 124) Finds the user with the specified username. First tries to match username case sensitively; if that fails, it tries case insensitively; but if more than one user matches the case insensitive search, it returns null.
Arguments
-
usernameString -
The username to look for
Server Accounts.findUserByEmail(email) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 140)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 140) Finds the user with the specified email. First tries to match email case sensitively; if that fails, it tries case insensitively; but if more than one user matches the case insensitive search, it returns null.
Arguments
-
emailString -
The email address to look for
Use the below functions to initiate password changes or resets from the server or the client.
Client Accounts.changePassword(oldPassword, newPassword, [callback]) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_client.js, line 151)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_client.js, line 151) Change the current user's password. Must be logged in.
Arguments
-
oldPasswordString -
The user's current password. This is not sent in plain text over the wire.
-
newPasswordString -
A new password for the user. This is not sent in plain text over the wire.
-
callbackFunction -
Optional callback. Called with no arguments on success, or with a single
Errorargument on failure.
Client Accounts.forgotPassword(options, [callback]) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_client.js, line 214)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_client.js, line 214) Request a forgot password email.
Arguments
-
callbackFunction -
Optional callback. Called with no arguments on success, or with a single
Errorargument on failure.
Options
-
emailString -
The email address to send a password reset link.
This triggers a call to Accounts.sendResetPasswordEmail on the server. When the user visits the link in this email, the callback registered with Accounts.onResetPasswordLink will be called.
If you are using the accounts-ui package, this is handled automatically. Otherwise, it is your responsibility to prompt the user for the new password and call resetPassword.
Client Accounts.resetPassword(token, newPassword, [callback]) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_client.js, line 235)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_client.js, line 235) Reset the password for a user using a token received in email. Logs the user in afterwards.
Arguments
-
tokenString -
The token retrieved from the reset password URL.
-
newPasswordString -
A new password for the user. This is not sent in plain text over the wire.
-
callbackFunction -
Optional callback. Called with no arguments on success, or with a single
Errorargument on failure.
This function accepts tokens passed into the callbacks registered with AccountsClient#onResetPasswordLink and Accounts.onEnrollmentLink.
Server Accounts.setPassword(userId, newPassword, [options]) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 475)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 475) Forcibly change the password for a user.
Arguments
-
userIdString -
The id of the user to update.
-
newPasswordString -
A new password for the user.
Options
-
logoutObject -
Logout all current connections with this userId (default: true)
Server Accounts.sendResetPasswordEmail(userId, [email]) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 529)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 529) Send an email with a link the user can use to reset their password.
Arguments
-
userIdString -
The id of the user to send email to.
-
emailString -
Optional. Which address of the user's to send the email to. This address must be in the user's
emailslist. Defaults to the first email in the list.
When the user visits the link in this email, the callback registered with AccountsClient#onResetPasswordLink will be called.
To customize the contents of the email, see Accounts.emailTemplates.
Server Accounts.sendEnrollmentEmail(userId, [email]) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 595)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 595) Send an email with a link the user can use to set their initial password.
Arguments
-
userIdString -
The id of the user to send email to.
-
emailString -
Optional. Which address of the user's to send the email to. This address must be in the user's
emailslist. Defaults to the first email in the list.
When the user visits the link in this email, the callback registered with Accounts.onEnrollmentLink will be called.
To customize the contents of the email, see Accounts.emailTemplates.
Server Accounts.sendVerificationEmail(userId, [email]) import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 735)
import { Accounts } from 'meteor/accounts-base' (accounts-password/password_server.js, line 735) Send an email with a link the user can use verify their email address.
Arguments
-
userIdString -
The id of the user to send email to.
-
emailString -
Optional. Which address of the user's to send the email to. This address must be in the user's
emailslist. Defaults to the first unverified email in the list.
When the user visits the link in this email, the callback registered with Accounts.onEmailVerificationLink will be called.
To customize the contents of the email, see Accounts.emailTemplates.
Client Accounts.onResetPasswordLink import { Accounts } from 'meteor/accounts-base' (accounts-base/url_client.js, line 91)
import { Accounts } from 'meteor/accounts-base' (accounts-base/url_client.js, line 91) Register a function to call when a reset password link is clicked in an email sent by Accounts.sendResetPasswordEmail. This function should be called in top-level code, not inside Meteor.startup().
Arguments
-
callbackFunction -
The function to call. It is given two arguments:
-
token: A password reset token that can be passed toAccounts.resetPassword. -
done: A function to call when the password reset UI flow is complete. The normal login process is suspended until this function is called, so that the password for user A can be reset even if user B was logged in.
-
Client Accounts.onEnrollmentLink import { Accounts } from 'meteor/accounts-base' (accounts-base/url_client.js, line 144)
import { Accounts } from 'meteor/accounts-base' (accounts-base/url_client.js, line 144) Register a function to call when an account enrollment link is clicked in an email sent by Accounts.sendEnrollmentEmail. This function should be called in top-level code, not inside Meteor.startup().
Arguments
-
callbackFunction -
The function to call. It is given two arguments:
-
token: A password reset token that can be passed toAccounts.resetPasswordto give the newly enrolled account a password. -
done: A function to call when the enrollment UI flow is complete. The normal login process is suspended until this function is called, so that user A can be enrolled even if user B was logged in.
-
Client Accounts.onEmailVerificationLink import { Accounts } from 'meteor/accounts-base' (accounts-base/url_client.js, line 117)
import { Accounts } from 'meteor/accounts-base' (accounts-base/url_client.js, line 117) Register a function to call when an email verification link is clicked in an email sent by Accounts.sendVerificationEmail. This function should be called in top-level code, not inside Meteor.startup().
Arguments
-
callbackFunction -
The function to call. It is given two arguments:
-
token: An email verification token that can be passed toAccounts.verifyEmail. -
done: A function to call when the email verification UI flow is complete. The normal login process is suspended until this function is called, so that the user can be notified that they are verifying their email before being logged in.
-
Server Accounts.emailTemplates import { Accounts } from 'meteor/accounts-base' (accounts-password/email_templates.js, line 21)
import { Accounts } from 'meteor/accounts-base' (accounts-password/email_templates.js, line 21) Options to customize emails sent from the Accounts system.
This is an Object with several fields that are used to generate text/html for the emails sent by sendResetPasswordEmail, sendEnrollmentEmail, and sendVerificationEmail.
Override fields of the object by assigning to them:
-
from: AStringwith an RFC5322 From address. By default, the email is sent from[email protected]. If you wish to receive email from users asking for help with their account, be sure to set this to an email address that you can receive email at. -
siteName: The public name of your application. Defaults to the DNS name of the application (eg:awesome.meteor.com). -
headers: AnObjectfor custom email headers as described inEmail.send. -
resetPassword: AnObjectwith the fields:-
from: AFunctionused to override thefromaddress defined by theemailTemplates.fromfield. -
subject: AFunctionthat takes a user object and returns aStringfor the subject line of a reset password email. -
text: An optionalFunctionthat takes a user object and a url, and returns the body text for a reset password email. -
html: An optionalFunctionthat takes a user object and a url, and returns the body html for a reset password email.
-
-
enrollAccount: Same asresetPassword, but for initial password setup for new accounts. -
verifyEmail: Same asresetPassword, but for verifying the users email address.
Example:
Accounts.emailTemplates.siteName = "AwesomeSite"; Accounts.emailTemplates.from = "AwesomeSite Admin <[email protected]>"; Accounts.emailTemplates.enrollAccount.subject = function (user) { return "Welcome to Awesome Town, " + user.profile.name; }; Accounts.emailTemplates.enrollAccount.text = function (user, url) { return "You have been selected to participate in building a better future!" + " To activate your account, simply click the link below:\n\n" + url; }; Accounts.emailTemplates.resetPassword.from = function () { // Overrides value set in Accounts.emailTemplates.from when resetting passwords return "AwesomeSite Password Reset <[email protected]>"; };
© 2011–2017 Meteor Development Group, Inc.
Licensed under the MIT License.
https://docs.meteor.com/v1.3.5/api/passwords.html