2020-08-07 00:24:46 +08:00
|
|
|
import { pInt, pString } from 'Common/Utils';
|
2021-03-18 19:33:13 +08:00
|
|
|
import { i18n, getNotification } from 'Common/Translator';
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2020-09-15 01:40:56 +08:00
|
|
|
import Remote from 'Remote/Admin/Fetch';
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2021-02-19 19:09:20 +08:00
|
|
|
import { decorateKoCommands } from 'Knoin/Knoin';
|
2021-01-24 17:25:23 +08:00
|
|
|
import { AbstractViewPopup } from 'Knoin/AbstractViews';
|
|
|
|
|
2021-03-15 05:36:23 +08:00
|
|
|
import { DomainAdminStore } from 'Stores/Admin/Domain';
|
|
|
|
|
2021-01-24 17:25:23 +08:00
|
|
|
class DomainPopupView extends AbstractViewPopup {
|
2016-08-17 06:01:20 +08:00
|
|
|
constructor() {
|
2021-01-24 17:25:23 +08:00
|
|
|
super('Domain');
|
2016-08-17 06:01:20 +08:00
|
|
|
|
2020-10-26 19:54:03 +08:00
|
|
|
this.addObservables({
|
|
|
|
edit: false,
|
|
|
|
saving: false,
|
|
|
|
savingError: '',
|
|
|
|
page: 'main',
|
|
|
|
sieveSettings: false,
|
|
|
|
|
|
|
|
testing: false,
|
|
|
|
testingDone: false,
|
|
|
|
testingImapError: false,
|
|
|
|
testingSieveError: false,
|
|
|
|
testingSmtpError: false,
|
|
|
|
testingImapErrorDesc: '',
|
|
|
|
testingSieveErrorDesc: '',
|
|
|
|
testingSmtpErrorDesc: '',
|
|
|
|
|
|
|
|
imapServerFocus: false,
|
|
|
|
sieveServerFocus: false,
|
|
|
|
smtpServerFocus: false,
|
|
|
|
|
|
|
|
name: '',
|
|
|
|
|
|
|
|
imapServer: '',
|
|
|
|
imapPort: '143',
|
2021-01-25 05:58:06 +08:00
|
|
|
imapSecure: 0,
|
2020-10-26 19:54:03 +08:00
|
|
|
imapShortLogin: false,
|
|
|
|
useSieve: false,
|
|
|
|
sieveServer: '',
|
|
|
|
sievePort: '4190',
|
2021-01-25 05:58:06 +08:00
|
|
|
sieveSecure: 0,
|
2020-10-26 19:54:03 +08:00
|
|
|
smtpServer: '',
|
|
|
|
smtpPort: '25',
|
2021-01-25 05:58:06 +08:00
|
|
|
smtpSecure: 0,
|
2020-10-26 19:54:03 +08:00
|
|
|
smtpShortLogin: false,
|
|
|
|
smtpAuth: true,
|
2021-03-22 21:17:18 +08:00
|
|
|
smtpSetSender: false,
|
2020-10-26 19:54:03 +08:00
|
|
|
smtpPhpMail: false,
|
|
|
|
whiteList: '',
|
|
|
|
aliasName: '',
|
|
|
|
|
|
|
|
enableSmartPorts: false
|
2016-08-17 06:01:20 +08:00
|
|
|
});
|
|
|
|
|
2020-10-26 21:44:34 +08:00
|
|
|
this.addComputables({
|
|
|
|
headerText: () => {
|
|
|
|
const name = this.name(),
|
|
|
|
aliasName = this.aliasName();
|
|
|
|
|
|
|
|
let result = '';
|
|
|
|
|
|
|
|
if (this.edit()) {
|
|
|
|
result = i18n('POPUPS_DOMAIN/TITLE_EDIT_DOMAIN', { 'NAME': name });
|
|
|
|
if (aliasName) {
|
|
|
|
result += ' ← ' + aliasName;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
result = name
|
|
|
|
? i18n('POPUPS_DOMAIN/TITLE_ADD_DOMAIN_WITH_NAME', { 'NAME': name })
|
|
|
|
: i18n('POPUPS_DOMAIN/TITLE_ADD_DOMAIN');
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
},
|
|
|
|
|
|
|
|
domainDesc: () => {
|
|
|
|
const name = this.name();
|
|
|
|
return !this.edit() && name ? i18n('POPUPS_DOMAIN/NEW_DOMAIN_DESC', { 'NAME': '*@' + name }) : '';
|
|
|
|
},
|
|
|
|
|
|
|
|
domainIsComputed: () => {
|
|
|
|
const usePhpMail = this.smtpPhpMail(),
|
|
|
|
useSieve = this.useSieve();
|
|
|
|
|
|
|
|
return (
|
|
|
|
this.name() &&
|
|
|
|
this.imapServer() &&
|
|
|
|
this.imapPort() &&
|
2021-03-14 19:15:48 +08:00
|
|
|
(useSieve ? this.sieveServer() && this.sievePort() : true) &&
|
2020-10-26 21:44:34 +08:00
|
|
|
((this.smtpServer() && this.smtpPort()) || usePhpMail)
|
|
|
|
);
|
|
|
|
},
|
|
|
|
|
|
|
|
canBeTested: () => !this.testing() && this.domainIsComputed(),
|
|
|
|
canBeSaved: () => !this.saving() && this.domainIsComputed()
|
|
|
|
});
|
|
|
|
|
2020-10-26 19:54:03 +08:00
|
|
|
this.addSubscribables({
|
|
|
|
testingImapError: value => value || this.testingImapErrorDesc(''),
|
|
|
|
testingSieveError: value => value || this.testingSieveErrorDesc(''),
|
|
|
|
testingSmtpError: value => value || this.testingSmtpErrorDesc(''),
|
|
|
|
|
|
|
|
page: () => this.sieveSettings(false),
|
|
|
|
|
|
|
|
// smart form improvements
|
|
|
|
imapServerFocus: value =>
|
|
|
|
value && this.name() && !this.imapServer() && this.imapServer(this.name().replace(/[.]?[*][.]?/g, '')),
|
|
|
|
|
|
|
|
sieveServerFocus: value =>
|
|
|
|
value && this.imapServer() && !this.sieveServer() && this.sieveServer(this.imapServer()),
|
|
|
|
|
|
|
|
smtpServerFocus: value => value && this.imapServer() && !this.smtpServer()
|
|
|
|
&& this.smtpServer(this.imapServer().replace(/imap/gi, 'smtp')),
|
|
|
|
|
|
|
|
imapSecure: value => {
|
|
|
|
if (this.enableSmartPorts()) {
|
|
|
|
const port = pInt(this.imapPort());
|
|
|
|
switch (pString(value)) {
|
|
|
|
case '0':
|
|
|
|
case '2':
|
|
|
|
if (993 === port) {
|
|
|
|
this.imapPort('143');
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '1':
|
|
|
|
if (143 === port) {
|
|
|
|
this.imapPort('993');
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
// no default
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
smtpSecure: value => {
|
|
|
|
if (this.enableSmartPorts()) {
|
|
|
|
const port = pInt(this.smtpPort());
|
|
|
|
switch (pString(value)) {
|
|
|
|
case '0':
|
|
|
|
if (465 === port || 587 === port) {
|
|
|
|
this.smtpPort('25');
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '1':
|
|
|
|
if (25 === port || 587 === port) {
|
|
|
|
this.smtpPort('465');
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '2':
|
|
|
|
if (25 === port || 465 === port) {
|
|
|
|
this.smtpPort('587');
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
// no default
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-08-17 06:01:20 +08:00
|
|
|
});
|
2021-02-19 19:09:20 +08:00
|
|
|
|
|
|
|
decorateKoCommands(this, {
|
|
|
|
createOrAddCommand: self => self.canBeSaved(),
|
|
|
|
testConnectionCommand: self => self.canBeTested(),
|
|
|
|
whiteListCommand: 1,
|
|
|
|
backCommand: 1,
|
|
|
|
sieveCommand: 1
|
|
|
|
});
|
2016-08-17 06:01:20 +08:00
|
|
|
}
|
2015-01-29 00:27:23 +08:00
|
|
|
|
2016-09-10 06:38:16 +08:00
|
|
|
createOrAddCommand() {
|
|
|
|
this.saving(true);
|
|
|
|
Remote.createOrUpdateDomain(
|
2020-07-20 21:47:33 +08:00
|
|
|
this.onDomainCreateOrSaveResponse.bind(this),
|
2021-01-21 17:00:12 +08:00
|
|
|
this
|
2016-09-10 06:38:16 +08:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
testConnectionCommand() {
|
|
|
|
this.page('main');
|
|
|
|
|
|
|
|
this.testingDone(false);
|
|
|
|
this.testingImapError(false);
|
|
|
|
this.testingSieveError(false);
|
|
|
|
this.testingSmtpError(false);
|
|
|
|
this.testing(true);
|
|
|
|
|
|
|
|
Remote.testConnectionForDomain(
|
2020-07-20 21:47:33 +08:00
|
|
|
this.onTestConnectionResponse.bind(this),
|
2021-01-21 17:00:12 +08:00
|
|
|
this
|
2016-09-10 06:38:16 +08:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
whiteListCommand() {
|
|
|
|
this.page('white-list');
|
|
|
|
}
|
|
|
|
|
|
|
|
backCommand() {
|
|
|
|
this.page('main');
|
|
|
|
}
|
|
|
|
|
|
|
|
sieveCommand() {
|
|
|
|
this.sieveSettings(!this.sieveSettings());
|
|
|
|
this.clearTesting();
|
|
|
|
}
|
|
|
|
|
2021-03-16 16:46:23 +08:00
|
|
|
onTestConnectionResponse(iError, oData) {
|
2016-08-17 06:01:20 +08:00
|
|
|
this.testing(false);
|
2021-03-18 21:48:21 +08:00
|
|
|
if (iError) {
|
|
|
|
this.testingImapError(true);
|
|
|
|
this.testingSieveError(true);
|
|
|
|
this.testingSmtpError(true);
|
|
|
|
this.sieveSettings(false);
|
|
|
|
} else {
|
2019-07-05 03:19:24 +08:00
|
|
|
let bImap = false,
|
2016-08-17 06:01:20 +08:00
|
|
|
bSieve = false;
|
2014-08-21 23:08:34 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.testingDone(true);
|
|
|
|
this.testingImapError(true !== oData.Result.Imap);
|
|
|
|
this.testingSieveError(true !== oData.Result.Sieve);
|
|
|
|
this.testingSmtpError(true !== oData.Result.Smtp);
|
2014-08-21 23:08:34 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
if (this.testingImapError() && oData.Result.Imap) {
|
2016-08-17 06:01:20 +08:00
|
|
|
bImap = true;
|
|
|
|
this.testingImapErrorDesc('');
|
|
|
|
this.testingImapErrorDesc(oData.Result.Imap);
|
2015-01-29 00:27:23 +08:00
|
|
|
}
|
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
if (this.testingSieveError() && oData.Result.Sieve) {
|
2016-08-17 06:01:20 +08:00
|
|
|
bSieve = true;
|
|
|
|
this.testingSieveErrorDesc('');
|
|
|
|
this.testingSieveErrorDesc(oData.Result.Sieve);
|
2015-04-10 06:05:49 +08:00
|
|
|
}
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
if (this.testingSmtpError() && oData.Result.Smtp) {
|
2016-08-17 06:01:20 +08:00
|
|
|
this.testingSmtpErrorDesc('');
|
|
|
|
this.testingSmtpErrorDesc(oData.Result.Smtp);
|
|
|
|
}
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
if (this.sieveSettings()) {
|
|
|
|
if (!bSieve && bImap) {
|
2016-08-17 06:01:20 +08:00
|
|
|
this.sieveSettings(false);
|
|
|
|
}
|
2019-07-05 03:19:24 +08:00
|
|
|
} else if (bSieve && !bImap) {
|
2016-06-30 08:02:45 +08:00
|
|
|
this.sieveSettings(true);
|
|
|
|
}
|
2016-08-17 06:01:20 +08:00
|
|
|
}
|
2016-06-30 08:02:45 +08:00
|
|
|
}
|
2014-11-20 05:32:20 +08:00
|
|
|
|
2021-03-18 19:33:13 +08:00
|
|
|
onDomainCreateOrSaveResponse(iError) {
|
2016-08-17 06:01:20 +08:00
|
|
|
this.saving(false);
|
2021-03-18 19:33:13 +08:00
|
|
|
if (iError) {
|
|
|
|
this.savingError(getNotification(iError));
|
2019-07-05 03:19:24 +08:00
|
|
|
} else {
|
2021-03-18 19:33:13 +08:00
|
|
|
DomainAdminStore.fetch();
|
|
|
|
this.closeCommand();
|
2016-06-30 08:02:45 +08:00
|
|
|
}
|
|
|
|
}
|
2014-05-01 00:24:45 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
clearTesting() {
|
|
|
|
this.testing(false);
|
|
|
|
this.testingDone(false);
|
|
|
|
this.testingImapError(false);
|
|
|
|
this.testingSieveError(false);
|
|
|
|
this.testingSmtpError(false);
|
|
|
|
}
|
2014-05-01 00:24:45 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
onHide() {
|
|
|
|
this.page('main');
|
|
|
|
this.sieveSettings(false);
|
|
|
|
}
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
onShow(oDomain) {
|
|
|
|
this.saving(false);
|
2013-11-16 06:21:12 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.page('main');
|
|
|
|
this.sieveSettings(false);
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.clearTesting();
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.clearForm();
|
2019-07-05 03:19:24 +08:00
|
|
|
if (oDomain) {
|
2016-08-17 06:01:20 +08:00
|
|
|
this.enableSmartPorts(false);
|
|
|
|
|
|
|
|
this.edit(true);
|
|
|
|
|
2020-10-17 19:53:04 +08:00
|
|
|
this.name(oDomain.Name);
|
|
|
|
this.imapServer(oDomain.IncHost);
|
2016-08-17 06:01:20 +08:00
|
|
|
this.imapPort('' + pInt(oDomain.IncPort));
|
2020-10-17 19:53:04 +08:00
|
|
|
this.imapSecure(oDomain.IncSecure);
|
2016-08-17 06:01:20 +08:00
|
|
|
this.imapShortLogin(!!oDomain.IncShortLogin);
|
|
|
|
this.useSieve(!!oDomain.UseSieve);
|
2020-10-17 19:53:04 +08:00
|
|
|
this.sieveServer(oDomain.SieveHost);
|
2016-08-17 06:01:20 +08:00
|
|
|
this.sievePort('' + pInt(oDomain.SievePort));
|
2020-10-17 19:53:04 +08:00
|
|
|
this.sieveSecure(oDomain.SieveSecure);
|
|
|
|
this.smtpServer(oDomain.OutHost);
|
2016-08-17 06:01:20 +08:00
|
|
|
this.smtpPort('' + pInt(oDomain.OutPort));
|
2020-10-17 19:53:04 +08:00
|
|
|
this.smtpSecure(oDomain.OutSecure);
|
2016-08-17 06:01:20 +08:00
|
|
|
this.smtpShortLogin(!!oDomain.OutShortLogin);
|
|
|
|
this.smtpAuth(!!oDomain.OutAuth);
|
2021-03-22 21:17:18 +08:00
|
|
|
this.smtpSetSender(!!oDomain.OutSetSender);
|
2016-08-17 06:01:20 +08:00
|
|
|
this.smtpPhpMail(!!oDomain.OutUsePhpMail);
|
2020-10-17 19:53:04 +08:00
|
|
|
this.whiteList(oDomain.WhiteList);
|
|
|
|
this.aliasName(oDomain.AliasName);
|
2016-08-17 06:01:20 +08:00
|
|
|
|
|
|
|
this.enableSmartPorts(true);
|
|
|
|
}
|
2016-06-30 08:02:45 +08:00
|
|
|
}
|
2014-08-21 23:08:34 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
clearForm() {
|
|
|
|
this.edit(false);
|
2014-11-20 05:32:20 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.page('main');
|
|
|
|
this.sieveSettings(false);
|
2013-11-16 06:21:12 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.enableSmartPorts(false);
|
2013-11-16 06:21:12 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.savingError('');
|
2013-11-16 06:21:12 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.name('');
|
2014-11-20 05:32:20 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.imapServer('');
|
2020-09-30 20:07:03 +08:00
|
|
|
this.imapPort('143');
|
2021-01-25 05:58:06 +08:00
|
|
|
this.imapSecure(0);
|
2016-08-17 06:01:20 +08:00
|
|
|
this.imapShortLogin(false);
|
2014-11-20 05:32:20 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.useSieve(false);
|
|
|
|
this.sieveServer('');
|
2020-09-30 20:07:03 +08:00
|
|
|
this.sievePort('4190');
|
2021-01-25 05:58:06 +08:00
|
|
|
this.sieveSecure(0);
|
2014-10-14 06:39:23 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.smtpServer('');
|
2020-09-30 20:07:03 +08:00
|
|
|
this.smtpPort('25');
|
2021-01-25 05:58:06 +08:00
|
|
|
this.smtpSecure(0);
|
2016-08-17 06:01:20 +08:00
|
|
|
this.smtpShortLogin(false);
|
|
|
|
this.smtpAuth(true);
|
2021-03-22 21:17:18 +08:00
|
|
|
this.smtpSetSender(true);
|
2016-08-17 06:01:20 +08:00
|
|
|
this.smtpPhpMail(false);
|
2013-11-16 06:21:12 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.whiteList('');
|
|
|
|
this.aliasName('');
|
|
|
|
this.enableSmartPorts(true);
|
|
|
|
}
|
|
|
|
}
|
2013-11-16 06:21:12 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
export { DomainPopupView, DomainPopupView as default };
|