RocketChat/Rocket.Chat

View on GitHub
apps/meteor/server/methods/sendForgotPasswordEmail.ts

Summary

Maintainability
A
25 mins
Test Coverage
import { Users } from '@rocket.chat/models';
import type { ServerMethods } from '@rocket.chat/ui-contexts';
import { Accounts } from 'meteor/accounts-base';
import { check } from 'meteor/check';
import { Meteor } from 'meteor/meteor';

import { settings } from '../../app/settings/server';
import { SystemLogger } from '../lib/logger/system';

declare module '@rocket.chat/ui-contexts' {
    // eslint-disable-next-line @typescript-eslint/naming-convention
    interface ServerMethods {
        sendForgotPasswordEmail(to: string): boolean | undefined;
    }
}

Meteor.methods<ServerMethods>({
    async sendForgotPasswordEmail(to) {
        check(to, String);

        const email = to.trim().toLowerCase();

        const user = await Users.findOneByEmailAddress(email, { projection: { _id: 1, services: 1 } });

        if (!user) {
            return true;
        }

        if (user.services && !user.services.password) {
            if (!settings.get('Accounts_AllowPasswordChangeForOAuthUsers')) {
                return false;
            }
        }

        try {
            Accounts.sendResetPasswordEmail(user._id, email);
            return true;
        } catch (error) {
            SystemLogger.error(error);
        }
    },
});