mirror of
https://github.com/the-djmaze/snappymail.git
synced 2025-01-01 04:22:15 +08:00
Bugfix: UserBackground failed
This commit is contained in:
parent
b655e0ad70
commit
c503aaca1d
4 changed files with 93 additions and 96 deletions
|
@ -1,5 +1,5 @@
|
||||||
import ko from 'ko';
|
import ko from 'ko';
|
||||||
import { doc, $htmlCL, elementById, leftPanelDisabled, Settings, SettingsGet } from 'Common/Globals';
|
import { $htmlCL, elementById, leftPanelDisabled, Settings, SettingsGet } from 'Common/Globals';
|
||||||
import { isArray, arrayLength } from 'Common/Utils';
|
import { isArray, arrayLength } from 'Common/Utils';
|
||||||
import { serverRequestRaw } from 'Common/Links';
|
import { serverRequestRaw } from 'Common/Links';
|
||||||
import { SaveSettingStatus } from 'Common/Enums';
|
import { SaveSettingStatus } from 'Common/Enums';
|
||||||
|
@ -7,6 +7,8 @@ import { SaveSettingStatus } from 'Common/Enums';
|
||||||
let __themeTimer = 0;
|
let __themeTimer = 0;
|
||||||
|
|
||||||
export const
|
export const
|
||||||
|
appEl = () => elementById('rl-app'),
|
||||||
|
|
||||||
ThemeStore = {
|
ThemeStore = {
|
||||||
theme: ko.observable(''),
|
theme: ko.observable(''),
|
||||||
themes: ko.observableArray(),
|
themes: ko.observableArray(),
|
||||||
|
@ -65,7 +67,7 @@ ThemeStore.isMobile.subscribe(value => $htmlCL.toggle('rl-mobile', value));
|
||||||
|
|
||||||
ThemeStore.fontSansSerif.subscribe(value => {
|
ThemeStore.fontSansSerif.subscribe(value => {
|
||||||
if (null != value) {
|
if (null != value) {
|
||||||
let cl = elementById('rl-app').classList;
|
let cl = appEl().classList;
|
||||||
cl.forEach(name => {
|
cl.forEach(name => {
|
||||||
if (name.startsWith('font') && !/font(Serif|Mono)/.test(name)) {
|
if (name.startsWith('font') && !/font(Serif|Mono)/.test(name)) {
|
||||||
cl.remove(name);
|
cl.remove(name);
|
||||||
|
@ -76,25 +78,20 @@ ThemeStore.fontSansSerif.subscribe(value => {
|
||||||
});
|
});
|
||||||
ThemeStore.fontSerif.subscribe(value => {
|
ThemeStore.fontSerif.subscribe(value => {
|
||||||
if (null != value) {
|
if (null != value) {
|
||||||
let cl = elementById('rl-app').classList;
|
let cl = appEl().classList;
|
||||||
cl.forEach(name => name.startsWith('fontSerif') && cl.remove(name));
|
cl.forEach(name => name.startsWith('fontSerif') && cl.remove(name));
|
||||||
value && cl.add('fontSerif'+value);
|
value && cl.add('fontSerif'+value);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
ThemeStore.fontMono.subscribe(value => {
|
ThemeStore.fontMono.subscribe(value => {
|
||||||
if (null != value) {
|
if (null != value) {
|
||||||
let cl = elementById('rl-app').classList;
|
let cl = appEl().classList;
|
||||||
cl.forEach(name => name.startsWith('fontMono') && cl.remove(name));
|
cl.forEach(name => name.startsWith('fontMono') && cl.remove(name));
|
||||||
value && cl.add('fontMono'+value);
|
value && cl.add('fontMono'+value);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
ThemeStore.userBackgroundHash.subscribe(value => {
|
ThemeStore.userBackgroundHash.subscribe(value => {
|
||||||
if (value) {
|
appEl().classList.toggle('UserBackground', !!value);
|
||||||
$htmlCL.add('UserBackground');
|
appEl().style.backgroundImage = value ? "url("+serverRequestRaw('UserBackground', value)+")" : null;
|
||||||
doc.body.style.backgroundImage = "url("+serverRequestRaw('UserBackground', value)+")";
|
|
||||||
} else {
|
|
||||||
$htmlCL.remove('UserBackground');
|
|
||||||
doc.body.removeAttribute('style');
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
|
|
||||||
.UserBackground body {
|
#rl-app.UserBackground {
|
||||||
background-size: cover;
|
background-size: cover;
|
||||||
background-repeat: no-repeat;
|
background-repeat: no-repeat;
|
||||||
background-position: center;
|
background-position: center;
|
||||||
|
|
|
@ -1028,90 +1028,6 @@ class Actions
|
||||||
return $this->DefaultResponse(__FUNCTION__, $aResponse);
|
return $this->DefaultResponse(__FUNCTION__, $aResponse);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function UploadBackground(): array
|
|
||||||
{
|
|
||||||
$oAccount = $this->getAccountFromToken();
|
|
||||||
|
|
||||||
if (!$this->GetCapa(Enumerations\Capa::USER_BACKGROUND)) {
|
|
||||||
return $this->FalseResponse(__FUNCTION__);
|
|
||||||
}
|
|
||||||
|
|
||||||
$sName = '';
|
|
||||||
$sHash = '';
|
|
||||||
|
|
||||||
$aFile = $this->GetActionParam('File', null);
|
|
||||||
$iError = $this->GetActionParam('Error', Enumerations\UploadError::UNKNOWN);
|
|
||||||
|
|
||||||
if ($oAccount && UPLOAD_ERR_OK === $iError && \is_array($aFile)) {
|
|
||||||
$sMimeType = \SnappyMail\File\MimeType::fromFile($aFile['tmp_name'], $aFile['name'])
|
|
||||||
?: \SnappyMail\File\MimeType::fromFilename($aFile['name'])
|
|
||||||
?: $aFile['type'];
|
|
||||||
if (\in_array($sMimeType, array('image/png', 'image/jpg', 'image/jpeg', 'image/webp'))) {
|
|
||||||
$sSavedName = 'upload-post-' . \md5($aFile['name'] . $aFile['tmp_name'])
|
|
||||||
. \SnappyMail\File\MimeType::toExtension($sContentType);
|
|
||||||
if (!$this->FilesProvider()->MoveUploadedFile($oAccount, $sSavedName, $aFile['tmp_name'])) {
|
|
||||||
$iError = Enumerations\UploadError::ON_SAVING;
|
|
||||||
} else {
|
|
||||||
$rData = $this->FilesProvider()->GetFile($oAccount, $sSavedName);
|
|
||||||
if (\is_resource($rData)) {
|
|
||||||
$sData = \stream_get_contents($rData);
|
|
||||||
if (!empty($sData) && \strlen($sData)) {
|
|
||||||
$sName = $aFile['name'];
|
|
||||||
if (empty($sName)) {
|
|
||||||
$sName = '_';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($this->StorageProvider()->Put($oAccount,
|
|
||||||
Providers\Storage\Enumerations\StorageType::CONFIG,
|
|
||||||
'background',
|
|
||||||
Utils::jsonEncode(array(
|
|
||||||
'Name' => $aFile['name'],
|
|
||||||
'ContentType' => $sMimeType,
|
|
||||||
'Raw' => \base64_encode($sData)
|
|
||||||
))
|
|
||||||
)) {
|
|
||||||
$oSettings = $this->SettingsProvider()->Load($oAccount);
|
|
||||||
if ($oSettings) {
|
|
||||||
$sHash = \MailSo\Base\Utils::Sha1Rand($sName . APP_VERSION . APP_SALT);
|
|
||||||
|
|
||||||
$oSettings->SetConf('UserBackgroundName', $sName);
|
|
||||||
$oSettings->SetConf('UserBackgroundHash', $sHash);
|
|
||||||
$this->SettingsProvider()->Save($oAccount, $oSettings);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
unset($sData);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (\is_resource($rData)) {
|
|
||||||
\fclose($rData);
|
|
||||||
}
|
|
||||||
|
|
||||||
unset($rData);
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->FilesProvider()->Clear($oAccount, $sSavedName);
|
|
||||||
} else {
|
|
||||||
$iError = Enumerations\UploadError::FILE_TYPE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (UPLOAD_ERR_OK !== $iError) {
|
|
||||||
$iClientError = Enumerations\UploadError::NORMAL;
|
|
||||||
$sError = $this->getUploadErrorMessageByCode($iError, $iClientError);
|
|
||||||
|
|
||||||
if (!empty($sError)) {
|
|
||||||
return $this->FalseResponse(__FUNCTION__, $iClientError, $sError);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->DefaultResponse(__FUNCTION__, !empty($sName) && !empty($sHash) ? array(
|
|
||||||
'Name' => $sName,
|
|
||||||
'Hash' => $sHash
|
|
||||||
) : false);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function Capa(bool $bAdmin, ?Model\Account $oAccount = null): array
|
public function Capa(bool $bAdmin, ?Model\Account $oAccount = null): array
|
||||||
{
|
{
|
||||||
static $aResult;
|
static $aResult;
|
||||||
|
|
|
@ -127,4 +127,88 @@ trait Themes
|
||||||
return $bLess ? (new \LessPHP\lessc())->compile($mResult) : $mResult;
|
return $bLess ? (new \LessPHP\lessc())->compile($mResult) : $mResult;
|
||||||
// : \str_replace(';}', '}', \preg_replace('/\\s*([:;{},])\\s*/', '\1', \preg_replace('/\\s+/', ' ', \preg_replace('#/\\*.*?\\*/#s', '', $mResult))));
|
// : \str_replace(';}', '}', \preg_replace('/\\s*([:;{},])\\s*/', '\1', \preg_replace('/\\s+/', ' ', \preg_replace('#/\\*.*?\\*/#s', '', $mResult))));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function UploadBackground(): array
|
||||||
|
{
|
||||||
|
$oAccount = $this->getAccountFromToken();
|
||||||
|
|
||||||
|
if (!$this->GetCapa(\RainLoop\Enumerations\Capa::USER_BACKGROUND)) {
|
||||||
|
return $this->FalseResponse(__FUNCTION__);
|
||||||
|
}
|
||||||
|
|
||||||
|
$sName = '';
|
||||||
|
$sHash = '';
|
||||||
|
|
||||||
|
$aFile = $this->GetActionParam('File', null);
|
||||||
|
$iError = $this->GetActionParam('Error', \RainLoop\Enumerations\UploadError::UNKNOWN);
|
||||||
|
|
||||||
|
if ($oAccount && UPLOAD_ERR_OK === $iError && \is_array($aFile)) {
|
||||||
|
$sMimeType = \SnappyMail\File\MimeType::fromFile($aFile['tmp_name'], $aFile['name'])
|
||||||
|
?: \SnappyMail\File\MimeType::fromFilename($aFile['name'])
|
||||||
|
?: $aFile['type'];
|
||||||
|
if (\in_array($sMimeType, array('image/png', 'image/jpg', 'image/jpeg', 'image/webp'))) {
|
||||||
|
$sSavedName = 'upload-post-' . \md5($aFile['name'] . $aFile['tmp_name'])
|
||||||
|
. \SnappyMail\File\MimeType::toExtension($sMimeType);
|
||||||
|
if (!$this->FilesProvider()->MoveUploadedFile($oAccount, $sSavedName, $aFile['tmp_name'])) {
|
||||||
|
$iError = \RainLoop\Enumerations\UploadError::ON_SAVING;
|
||||||
|
} else {
|
||||||
|
$rData = $this->FilesProvider()->GetFile($oAccount, $sSavedName);
|
||||||
|
if (\is_resource($rData)) {
|
||||||
|
$sData = \stream_get_contents($rData);
|
||||||
|
if (!empty($sData) && \strlen($sData)) {
|
||||||
|
$sName = $aFile['name'];
|
||||||
|
if (empty($sName)) {
|
||||||
|
$sName = '_';
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->StorageProvider()->Put($oAccount,
|
||||||
|
\RainLoop\Providers\Storage\Enumerations\StorageType::CONFIG,
|
||||||
|
'background',
|
||||||
|
\RainLoop\Utils::jsonEncode(array(
|
||||||
|
'Name' => $aFile['name'],
|
||||||
|
'ContentType' => $sMimeType,
|
||||||
|
'Raw' => \base64_encode($sData)
|
||||||
|
))
|
||||||
|
)) {
|
||||||
|
$oSettings = $this->SettingsProvider()->Load($oAccount);
|
||||||
|
if ($oSettings) {
|
||||||
|
$sHash = \MailSo\Base\Utils::Sha1Rand($sName . APP_VERSION . APP_SALT);
|
||||||
|
|
||||||
|
$oSettings->SetConf('UserBackgroundName', $sName);
|
||||||
|
$oSettings->SetConf('UserBackgroundHash', $sHash);
|
||||||
|
$this->SettingsProvider()->Save($oAccount, $oSettings);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
unset($sData);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (\is_resource($rData)) {
|
||||||
|
\fclose($rData);
|
||||||
|
}
|
||||||
|
|
||||||
|
unset($rData);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->FilesProvider()->Clear($oAccount, $sSavedName);
|
||||||
|
} else {
|
||||||
|
$iError = \RainLoop\Enumerations\UploadError::FILE_TYPE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (UPLOAD_ERR_OK !== $iError) {
|
||||||
|
$iClientError = \RainLoop\Enumerations\UploadError::NORMAL;
|
||||||
|
$sError = $this->getUploadErrorMessageByCode($iError, $iClientError);
|
||||||
|
|
||||||
|
if (!empty($sError)) {
|
||||||
|
return $this->FalseResponse(__FUNCTION__, $iClientError, $sError);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->DefaultResponse(__FUNCTION__, !empty($sName) && !empty($sHash) ? array(
|
||||||
|
'Name' => $sName,
|
||||||
|
'Hash' => $sHash
|
||||||
|
) : false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue