summaryrefslogtreecommitdiffstats
path: root/models/settings.js
diff options
context:
space:
mode:
authorLauri Ojansivu <x@xet7.org>2017-11-29 14:19:49 +0200
committerLauri Ojansivu <x@xet7.org>2017-11-29 14:19:49 +0200
commited95542b675aa34dee1c6eaafb1fb3a157215039 (patch)
tree4daa8de28d5b7604630b793f0043550eaa2476a7 /models/settings.js
parent9c283112edce9e7dd4bc1bd3b99a64b297082256 (diff)
parent54036fd7a3ac9bf25b6c601890491af66571d5ff (diff)
downloadwekan-ed95542b675aa34dee1c6eaafb1fb3a157215039.tar.gz
wekan-ed95542b675aa34dee1c6eaafb1fb3a157215039.tar.bz2
wekan-ed95542b675aa34dee1c6eaafb1fb3a157215039.zip
Merge branch 'devel'
Diffstat (limited to 'models/settings.js')
-rw-r--r--models/settings.js26
1 files changed, 26 insertions, 0 deletions
diff --git a/models/settings.js b/models/settings.js
index a02bb3fb..34f693d9 100644
--- a/models/settings.js
+++ b/models/settings.js
@@ -141,5 +141,31 @@ if (Meteor.isServer) {
}
});
},
+
+ sendSMTPTestEmail() {
+ if (!Meteor.userId()) {
+ throw new Meteor.Error('invalid-user');
+ }
+ const user = Meteor.user();
+ if (!user.emails && !user.emails[0] && user.emails[0].address) {
+ throw new Meteor.Error('email-invalid');
+ }
+ this.unblock();
+ const lang = user.getLanguage();
+ try {
+ Email.send({
+ to: user.emails[0].address,
+ from: Accounts.emailTemplates.from,
+ subject: TAPi18n.__('email-smtp-test-subject', {lng: lang}),
+ text: TAPi18n.__('email-smtp-test-text', {lng: lang}),
+ });
+ } catch ({message}) {
+ throw new Meteor.Error('email-fail', `${TAPi18n.__('email-fail-text', {lng: lang})}: ${ message }`, message);
+ }
+ return {
+ message: 'email-sent',
+ email: user.emails[0].address,
+ };
+ },
});
}