1
0
mirror of https://github.com/ONLYOFFICE/OneClickInstall.git synced 2025-04-18 16:44:00 +03:00

upgrade to 1.5.0

This commit is contained in:
Alexey Bannov 2016-07-06 17:21:44 +03:00
parent 6e7c7f92e0
commit d5eee968fe
65 changed files with 3594 additions and 1696 deletions

View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="utf-8"?>
<packages>
<package id="dotless" version="1.3.1" />
<package id="log4net" version="1.2.10" />
<package id="log4net" version="2.0.3" />
<package id="Microsoft.AspNet.Mvc" version="4.0.40804" targetFramework="net45" />
<package id="Microsoft.AspNet.Razor" version="2.0.20710" targetFramework="net45" />
<package id="Microsoft.AspNet.Web.Optimization" version="1.1.3" targetFramework="net45" />

View File

@ -1,179 +0,0 @@
Apache License
Version 2.0, January 2004
http://www.apache.org/licenses/
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
1. Definitions.
"License" shall mean the terms and conditions for use, reproduction,
and distribution as defined by Sections 1 through 9 of this document.
"Licensor" shall mean the copyright owner or entity authorized by
the copyright owner that is granting the License.
"Legal Entity" shall mean the union of the acting entity and all
other entities that control, are controlled by, or are under common
control with that entity. For the purposes of this definition,
"control" means (i) the power, direct or indirect, to cause the
direction or management of such entity, whether by contract or
otherwise, or (ii) ownership of fifty percent (50%) or more of the
outstanding shares, or (iii) beneficial ownership of such entity.
"You" (or "Your") shall mean an individual or Legal Entity
exercising permissions granted by this License.
"Source" form shall mean the preferred form for making modifications,
including but not limited to software source code, documentation
source, and configuration files.
"Object" form shall mean any form resulting from mechanical
transformation or translation of a Source form, including but
not limited to compiled object code, generated documentation,
and conversions to other media types.
"Work" shall mean the work of authorship, whether in Source or
Object form, made available under the License, as indicated by a
copyright notice that is included in or attached to the work
(an example is provided in the Appendix below).
"Derivative Works" shall mean any work, whether in Source or Object
form, that is based on (or derived from) the Work and for which the
editorial revisions, annotations, elaborations, or other modifications
represent, as a whole, an original work of authorship. For the purposes
of this License, Derivative Works shall not include works that remain
separable from, or merely link (or bind by name) to the interfaces of,
the Work and Derivative Works thereof.
"Contribution" shall mean any work of authorship, including
the original version of the Work and any modifications or additions
to that Work or Derivative Works thereof, that is intentionally
submitted to Licensor for inclusion in the Work by the copyright owner
or by an individual or Legal Entity authorized to submit on behalf of
the copyright owner. For the purposes of this definition, "submitted"
means any form of electronic, verbal, or written communication sent
to the Licensor or its representatives, including but not limited to
communication on electronic mailing lists, source code control systems,
and issue tracking systems that are managed by, or on behalf of, the
Licensor for the purpose of discussing and improving the Work, but
excluding communication that is conspicuously marked or otherwise
designated in writing by the copyright owner as "Not a Contribution."
"Contributor" shall mean Licensor and any individual or Legal Entity
on behalf of whom a Contribution has been received by Licensor and
subsequently incorporated within the Work.
2. Grant of Copyright License. Subject to the terms and conditions of
this License, each Contributor hereby grants to You a perpetual,
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
copyright license to reproduce, prepare Derivative Works of,
publicly display, publicly perform, sublicense, and distribute the
Work and such Derivative Works in Source or Object form.
3. Grant of Patent License. Subject to the terms and conditions of
this License, each Contributor hereby grants to You a perpetual,
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
(except as stated in this section) patent license to make, have made,
use, offer to sell, sell, import, and otherwise transfer the Work,
where such license applies only to those patent claims licensable
by such Contributor that are necessarily infringed by their
Contribution(s) alone or by combination of their Contribution(s)
with the Work to which such Contribution(s) was submitted. If You
institute patent litigation against any entity (including a
cross-claim or counterclaim in a lawsuit) alleging that the Work
or a Contribution incorporated within the Work constitutes direct
or contributory patent infringement, then any patent licenses
granted to You under this License for that Work shall terminate
as of the date such litigation is filed.
4. Redistribution. You may reproduce and distribute copies of the
Work or Derivative Works thereof in any medium, with or without
modifications, and in Source or Object form, provided that You
meet the following conditions:
(a) You must give any other recipients of the Work or
Derivative Works a copy of this License; and
(b) You must cause any modified files to carry prominent notices
stating that You changed the files; and
(c) You must retain, in the Source form of any Derivative Works
that You distribute, all copyright, patent, trademark, and
attribution notices from the Source form of the Work,
excluding those notices that do not pertain to any part of
the Derivative Works; and
(d) If the Work includes a "NOTICE" text file as part of its
distribution, then any Derivative Works that You distribute must
include a readable copy of the attribution notices contained
within such NOTICE file, excluding those notices that do not
pertain to any part of the Derivative Works, in at least one
of the following places: within a NOTICE text file distributed
as part of the Derivative Works; within the Source form or
documentation, if provided along with the Derivative Works; or,
within a display generated by the Derivative Works, if and
wherever such third-party notices normally appear. The contents
of the NOTICE file are for informational purposes only and
do not modify the License. You may add Your own attribution
notices within Derivative Works that You distribute, alongside
or as an addendum to the NOTICE text from the Work, provided
that such additional attribution notices cannot be construed
as modifying the License.
You may add Your own copyright statement to Your modifications and
may provide additional or different license terms and conditions
for use, reproduction, or distribution of Your modifications, or
for any such Derivative Works as a whole, provided Your use,
reproduction, and distribution of the Work otherwise complies with
the conditions stated in this License.
5. Submission of Contributions. Unless You explicitly state otherwise,
any Contribution intentionally submitted for inclusion in the Work
by You to the Licensor shall be under the terms and conditions of
this License, without any additional terms or conditions.
Notwithstanding the above, nothing herein shall supersede or modify
the terms of any separate license agreement you may have executed
with Licensor regarding such Contributions.
6. Trademarks. This License does not grant permission to use the trade
names, trademarks, service marks, or product names of the Licensor,
except as required for reasonable and customary use in describing the
origin of the Work and reproducing the content of the NOTICE file.
7. Disclaimer of Warranty. Unless required by applicable law or
agreed to in writing, Licensor provides the Work (and each
Contributor provides its Contributions) on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
implied, including, without limitation, any warranties or conditions
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
PARTICULAR PURPOSE. You are solely responsible for determining the
appropriateness of using or redistributing the Work and assume any
risks associated with Your exercise of permissions under this License.
8. Limitation of Liability. In no event and under no legal theory,
whether in tort (including negligence), contract, or otherwise,
unless required by applicable law (such as deliberate and grossly
negligent acts) or agreed to in writing, shall any Contributor be
liable to You for damages, including any direct, indirect, special,
incidental, or consequential damages of any character arising as a
result of this License or out of the use or inability to use the
Work (including but not limited to damages for loss of goodwill,
work stoppage, computer failure or malfunction, or any and all
other commercial damages or losses), even if such Contributor
has been advised of the possibility of such damages.
9. Accepting Warranty or Additional Liability. While redistributing
the Work or Derivative Works thereof, You may choose to offer,
and charge a fee for, acceptance of support, warranty, indemnity,
or other liability obligations and/or rights consistent with this
License. However, in accepting such obligations, You may act only
on Your own behalf and on Your sole responsibility, not on behalf
of any other Contributor, and only if You agree to indemnify,
defend, and hold each Contributor harmless for any liability
incurred by, or claims asserted against, such Contributor by reason
of your accepting any such warranty or additional liability.
END OF TERMS AND CONDITIONS
Copyright (c) 2009-2010 dotless project, http://www.dotlesscss.com

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -19,12 +19,8 @@
namespace OneClickInstallation.Classes
{
public class EmailSender
public class ImageTag
{
public string Host { get; set; }
public int Port { get; set; }
public string Email { get; set; }
public string Password { get; set; }
public bool EnableSsl { get; set; }
public string Name { get; set; }
}
}

View File

@ -32,9 +32,13 @@ namespace OneClickInstallation.Classes
public class InstallationManager : IDisposable
{
private string UserId { get; set; }
private string LicenseKey { get; set; }
private bool Enterprise { get; set; }
private ConnectionInfo ConnectionInfo { get; set; }
private InstallationProgressModel InstallationProgress { get; set; }
private InstallationComponentsModel InstallationComponents { get; set; }
private InstallationComponentsModel InstalledComponents { get; set; }
private SshClient _sshClient;
private SftpClient _sftpClient;
@ -85,9 +89,12 @@ namespace OneClickInstallation.Classes
public InstallationManager(string userId, ConnectionSettingsModel connectionSettings, InstallationComponentsModel installationComponents = null)
{
UserId = userId;
LicenseKey = connectionSettings.LicenseKey;
Enterprise = connectionSettings.Enterprise;
ConnectionInfo = GetConnectionInfo(connectionSettings);
InstallationProgress = CacheHelper.GetInstallationProgress(userId) ?? new InstallationProgressModel();
InstallationComponents = installationComponents;
InstalledComponents = CacheHelper.GetInstalledComponents(userId) ?? new InstallationComponentsModel();
}
public void StartInstallation()
@ -98,22 +105,24 @@ namespace OneClickInstallation.Classes
UploadFiles();
var osInfo = GetOsInfo(FileMap.GetOsInfoScript);
var osInfo = GetOsInfo(FileMap.GetOsInfoScript, InstallationProgressStep.GetOsInfo);
CheckPorts();
InstallDocker(osInfo);
if (InstallationComponents.DocumentServer)
InstallDocumentServer();
CreateNetwork();
if (InstallationComponents.MailServer)
InstallMailServer();
InstallDocumentServer();
if (InstallationComponents.CommunityServer)
InstallCommunityServer();
InstallMailServer();
CheckPreviousVersion(FileMap.CheckPreviousVersionScript);
if (Enterprise)
InstallControlPanel();
InstallCommunityServer();
CheckPreviousVersion(FileMap.CheckPreviousVersionScript, true);
WarmUp();
}
@ -131,17 +140,20 @@ namespace OneClickInstallation.Classes
}
}
public InstallationComponentsModel Connect()
public Tuple<OsInfo, InstallationComponentsModel> Connect()
{
var tmpCheckPreviousVersionScript = new FileMap("~/Executables/tools/check-previous-version.sh", "./");
var tmpGetOsInfoScript = new FileMap("~/Executables/tools/get-os-info.sh", "./");
UploadFile(tmpCheckPreviousVersionScript);
UploadFile(tmpCheckPreviousVersionScript, tmpGetOsInfoScript);
CheckPreviousVersion(tmpCheckPreviousVersionScript);
CheckPreviousVersion(tmpCheckPreviousVersionScript, false);
var osInfo = GetOsInfo(tmpGetOsInfoScript, null);
SftpClient.DeleteFile(tmpCheckPreviousVersionScript.RemotePath);
SftpClient.DeleteFile(tmpGetOsInfoScript.RemotePath);
return CacheHelper.GetInstalledComponents(UserId);
return new Tuple<OsInfo, InstallationComponentsModel>(osInfo, CacheHelper.GetInstalledComponents(UserId));
}
private static ConnectionInfo GetConnectionInfo(ConnectionSettingsModel connectionSettings)
@ -169,14 +181,36 @@ namespace OneClickInstallation.Classes
CreateDirectories();
UploadFile(FileMap.GetOsInfoScript,
FileMap.CheckPortsScript,
FileMap.CheckPreviousVersionScript,
FileMap.MakeDirScript,
FileMap.RunDockerScript,
FileMap.RunCommunityServerScript,
FileMap.RunDocumentServerScript,
FileMap.RunMailServerScript);
var files = new List<FileMap>
{
FileMap.RunDockerScript,
FileMap.CheckBindingsScript,
FileMap.CheckPortsScript,
FileMap.CheckPreviousVersionScript,
FileMap.GetAvailableVersionScript,
FileMap.GetOsInfoScript,
FileMap.LoginDockerScript,
FileMap.MakeDirScript,
FileMap.MakeNetworkScript,
FileMap.PullImageScript,
FileMap.RemoveContainerScript,
FileMap.RunCommunityServerScript,
FileMap.RunControlPanelScript,
FileMap.RunDocumentServerScript,
FileMap.RunMailServerScript
};
if (Enterprise && !string.IsNullOrEmpty(LicenseKey))
{
files.Add(FileMap.MakeLicenseFileMap(LicenseKey, "DocumentServer"));
files.Add(FileMap.MakeLicenseFileMap(LicenseKey, "MailServer"));
files.Add(FileMap.MakeLicenseFileMap(LicenseKey, "CommunityServer"));
files.Add(FileMap.MakeLicenseFileMap(LicenseKey, "ControlPanel"));
}
UploadFile(files.ToArray());
}
private void UploadFile(params FileMap[] files)
@ -190,7 +224,7 @@ namespace OneClickInstallation.Classes
using (var fileStream = File.OpenRead(file.LocalPath))
{
SftpClient.UploadFile(fileStream, file.FileName, true);
SftpClient.UploadFile(fileStream, file.IsScriptFile ? file.FileName : "license.lic", true);
}
}
@ -208,180 +242,196 @@ namespace OneClickInstallation.Classes
SftpClient.DeleteFile(tmpScript.RemotePath);
}
private OsInfo GetOsInfo(FileMap script)
private OsInfo GetOsInfo(FileMap script, InstallationProgressStep? progressStep)
{
InstallationProgress.Step = InstallationProgressStep.GetOsInfo;
CacheHelper.SetInstallationProgress(UserId, InstallationProgress);
using (var stream = SshClient.CreateShellStream("terminal", 150, 24, 800, 600, 1024))
{
stream.WriteLine(string.Format("sudo bash {0}", script.RemotePath));
var output = stream.Expect(Settings.InstallationStopPattern);
if (output.Contains(Settings.InstallationSuccessPattern))
InstallationProgress.ProgressText += output;
if (output.Contains(Settings.InstallationErrorPattern))
throw new Exception(output);
}
var output = RunScript(progressStep, script);
var osInfo = new OsInfo
{
Dist = GetTerminalParam(InstallationProgress.ProgressText, "DIST"),
Ver = GetTerminalParam(InstallationProgress.ProgressText, "REV"),
Type = GetTerminalParam(InstallationProgress.ProgressText, "MACH"),
Kernel = GetTerminalParam(InstallationProgress.ProgressText, "KERNEL")
};
{
Dist = GetTerminalParam(output, "DIST"),
Ver = GetTerminalParam(output, "REV"),
Type = GetTerminalParam(output, "MACH"),
Kernel = GetTerminalParam(output, "KERNEL")
};
CacheHelper.SetOsInfo(UserId, osInfo);
return osInfo;
}
private void CheckPorts()
{
InstallationProgress.Step = InstallationProgressStep.CheckPorts;
CacheHelper.SetInstallationProgress(UserId, InstallationProgress);
var ports = new List<int>();
using (var stream = SshClient.CreateShellStream("terminal", 150, 24, 800, 600, 1024))
{
stream.WriteLine(string.Format("sudo bash {0} {1}",
FileMap.CheckPortsScript.RemotePath,
InstallationComponents.MailServer.ToString().ToLower()));
if (!string.IsNullOrEmpty(InstallationComponents.CommunityServerVersion) && string.IsNullOrEmpty(InstalledComponents.CommunityServerVersion))
ports.AddRange(new[] {80, 443, 5222});
var output = stream.Expect(Settings.InstallationStopPattern);
if (!string.IsNullOrEmpty(InstallationComponents.MailServerVersion) && string.IsNullOrEmpty(InstalledComponents.MailServerVersion))
ports.AddRange(new[] {25, 143, 587});
if (output.Contains(Settings.InstallationSuccessPattern))
InstallationProgress.ProgressText += output;
if (output.Contains(Settings.InstallationErrorPattern))
throw new Exception(output);
}
if (ports.Count > 0)
RunScript(InstallationProgressStep.CheckPorts, FileMap.CheckPortsScript, string.Join(",", ports));
}
private void MakeDirectories(FileMap script)
{
using (var stream = SshClient.CreateShellStream("terminal", 150, 24, 800, 600, 1024))
{
stream.WriteLine(string.Format("sudo bash {0} \"{1}\"", script.RemotePath, Settings.RemoteServerDir));
var output = stream.Expect(Settings.InstallationSuccessPattern);
InstallationProgress.ProgressText += output;
}
RunScript(null, script);
}
private void CheckPreviousVersion(FileMap script)
private void CheckPreviousVersion(FileMap script, bool useSudo)
{
using (var stream = SshClient.CreateShellStream("terminal", 150, 24, 800, 600, 1024))
var output = RunScript(null,
script,
useSudo,
"-cc " + Settings.DockerCommunityContainerName,
"-dc " + Settings.DockerDocumentContainerName,
"-mc " + Settings.DockerMailContainerName,
"-cpc " + Settings.DockerControlPanelContainerName);
InstallationComponents = new InstallationComponentsModel
{
stream.WriteLine(string.Format("bash {0}", script.RemotePath));
var output = stream.Expect(Settings.InstallationStopPattern);
if (output.Contains(Settings.InstallationSuccessPattern))
{
InstallationComponents = new InstallationComponentsModel
{
MailServer = !string.IsNullOrEmpty(GetTerminalParam(output, "MAIL_SERVER_ID")),
DocumentServer = !string.IsNullOrEmpty(GetTerminalParam(output, "DOCUMENT_SERVER_ID")),
CommunityServer = !string.IsNullOrEmpty(GetTerminalParam(output, "COMMUNITY_SERVER_ID"))
};
InstallationProgress.ProgressText += output;
}
if (output.Contains(Settings.InstallationErrorPattern))
throw new Exception(output);
}
MailServerVersion = GetTerminalParam(output, "MAIL_SERVER_VERSION"),
DocumentServerVersion = GetTerminalParam(output, "DOCUMENT_SERVER_VERSION"),
CommunityServerVersion = GetTerminalParam(output, "COMMUNITY_SERVER_VERSION"),
ControlPanelVersion = GetTerminalParam(output, "CONTROL_PANEL_VERSION"),
LicenseFileExist = bool.Parse(GetTerminalParam(output, "LICENSE_FILE_EXIST"))
};
CacheHelper.SetInstalledComponents(UserId, InstallationComponents.IsEmpty ? null : InstallationComponents);
}
private void InstallDocker(OsInfo osInfo, bool afterReboot = false)
private void InstallDocker(OsInfo osInfo)
{
if(afterReboot)
CheckPorts();
RunScript(InstallationProgressStep.InstallDocker,
FileMap.RunDockerScript,
true,
osInfo.Dist,
osInfo.Ver,
osInfo.Kernel,
osInfo.Type);
}
var needReboot = false;
InstallationProgress.Step = InstallationProgressStep.InstallDocker;
CacheHelper.SetInstallationProgress(UserId, InstallationProgress);
var command = string.Format("sudo bash {0} \"{1}\" \"{2}\" \"{3}\" \"{4}\" {5}",
FileMap.RunDockerScript.RemotePath,
osInfo.Dist,
osInfo.Ver,
osInfo.Type,
osInfo.Kernel,
afterReboot ? true.ToString().ToLower() : string.Empty);
using (var stream = SshClient.CreateShellStream("terminal", 150, 24, 800, 600, 1024))
{
stream.WriteLine(command);
var output = stream.Expect(Settings.InstallationStopPattern);
if (output.Contains(Settings.InstallationRebootPattern))
{
InstallationProgress.ProgressText += output;
InstallationProgress.Step = InstallationProgressStep.RebootServer;
CacheHelper.SetInstallationProgress(UserId, InstallationProgress);
needReboot = true;
stream.WriteLine("sudo reboot");
System.Threading.Thread.Sleep(10000);
}
else
{
if (output.Contains(Settings.InstallationSuccessPattern))
InstallationProgress.ProgressText += output;
if (output.Contains(Settings.InstallationErrorPattern))
throw new Exception(output);
}
}
if (needReboot)
{
InstallDocker(osInfo, true);
}
private void CreateNetwork()
{
RunScript(null, FileMap.MakeNetworkScript, true);
}
private void InstallCommunityServer()
{
InstallServer(InstallationProgressStep.InstallCommunityServer, FileMap.RunCommunityServerScript);
if (string.IsNullOrEmpty(InstallationComponents.CommunityServerVersion)) return;
var notExist = string.IsNullOrEmpty(InstalledComponents.CommunityServerVersion);
RunScript(InstallationProgressStep.InstallCommunityServer,
FileMap.RunCommunityServerScript,
"-i " + (Enterprise ? Settings.DockerEnterpriseCommunityImageName : Settings.DockerCommunityImageName),
"-v " + (notExist ? InstallationComponents.CommunityServerVersion : InstalledComponents.CommunityServerVersion),
"-c " + Settings.DockerCommunityContainerName,
"-dc " + Settings.DockerDocumentContainerName,
"-mc " + Settings.DockerMailContainerName,
"-cc " + Settings.DockerControlPanelContainerName,
"-p " + Settings.DockerHubPassword,
"-un " + Settings.DockerHubUserName,
notExist ? string.Empty : "-u");
if (!notExist) return;
InstalledComponents.CommunityServerVersion = InstallationComponents.CommunityServerVersion;
CacheHelper.SetInstalledComponents(UserId, InstalledComponents);
}
private void InstallDocumentServer()
{
InstallServer(InstallationProgressStep.InstallDocumentServer, FileMap.RunDocumentServerScript);
if (string.IsNullOrEmpty(InstallationComponents.DocumentServerVersion)) return;
var notExist = string.IsNullOrEmpty(InstalledComponents.DocumentServerVersion);
RunScript(InstallationProgressStep.InstallDocumentServer,
FileMap.RunDocumentServerScript,
"-i " + (Enterprise ? Settings.DockerEnterpriseDocumentImageName : Settings.DockerDocumentImageName),
"-v " + (notExist ? InstallationComponents.DocumentServerVersion : InstalledComponents.DocumentServerVersion),
"-c " + Settings.DockerDocumentContainerName,
"-p " + Settings.DockerHubPassword,
"-un " + Settings.DockerHubUserName,
notExist ? string.Empty : "-u");
if (!notExist) return;
InstalledComponents.DocumentServerVersion = InstallationComponents.DocumentServerVersion;
CacheHelper.SetInstalledComponents(UserId, InstalledComponents);
}
private void InstallMailServer()
{
InstallServer(InstallationProgressStep.InstallMailServer, FileMap.RunMailServerScript, InstallationComponents.MailDomain);
if (string.IsNullOrEmpty(InstallationComponents.MailServerVersion)) return;
var notExist = string.IsNullOrEmpty(InstalledComponents.MailServerVersion);
RunScript(InstallationProgressStep.InstallMailServer,
FileMap.RunMailServerScript,
"-i " + (Enterprise ? Settings.DockerEnterpriseMailImageName : Settings.DockerMailImageName),
"-v " + (notExist ? InstallationComponents.MailServerVersion : InstalledComponents.MailServerVersion),
"-c " + Settings.DockerMailContainerName,
string.IsNullOrEmpty(InstallationComponents.MailDomain) ? string.Empty : "-d " + InstallationComponents.MailDomain,
"-p " + Settings.DockerHubPassword,
"-un " + Settings.DockerHubUserName,
notExist ? string.Empty : "-u");
if (!notExist) return;
InstalledComponents.MailServerVersion = InstallationComponents.MailServerVersion;
CacheHelper.SetInstalledComponents(UserId, InstalledComponents);
}
private void InstallServer(InstallationProgressStep progressStep, FileMap runServerScript, string serverScriptParam = "")
private void InstallControlPanel()
{
InstallationProgress.Step = progressStep;
CacheHelper.SetInstallationProgress(UserId, InstallationProgress);
if (string.IsNullOrEmpty(InstallationComponents.ControlPanelVersion)) return;
using (var stream = SshClient.CreateShellStream("terminal", 150, 24, 800, 600, 1024))
var notExist = string.IsNullOrEmpty(InstalledComponents.ControlPanelVersion);
RunScript(InstallationProgressStep.InstallControlPanel,
FileMap.RunControlPanelScript,
"-i " + (Enterprise ? Settings.DockerEnterpriseControlPanelImageName : Settings.DockerControlPanelImageName),
"-v " + (notExist ? InstallationComponents.ControlPanelVersion : InstalledComponents.ControlPanelVersion),
"-c " + Settings.DockerControlPanelContainerName,
"-p " + Settings.DockerHubPassword,
"-un " + Settings.DockerHubUserName,
notExist ? string.Empty : "-u");
if (!notExist) return;
InstalledComponents.ControlPanelVersion = InstallationComponents.ControlPanelVersion;
CacheHelper.SetInstalledComponents(UserId, InstalledComponents);
}
private string RunScript(InstallationProgressStep? progressStep, FileMap runServerScript, params string[] scriptParams)
{
return RunScript(progressStep, runServerScript, true, scriptParams);
}
private string RunScript(InstallationProgressStep? progressStep, FileMap runServerScript, bool useSudo, params string[] scriptParams)
{
if (progressStep.HasValue)
{
stream.WriteLine(!string.IsNullOrEmpty(serverScriptParam)
? string.Format("sudo bash {0} \"{1}\"", runServerScript.RemotePath, serverScriptParam)
: string.Format("sudo bash {0}", runServerScript.RemotePath));
InstallationProgress.Step = progressStep.Value;
CacheHelper.SetInstallationProgress(UserId, InstallationProgress);
}
var commandFormat = (useSudo ? "sudo " : string.Empty) + "bash {0} {1}";
using (var stream = SshClient.CreateShellStream("terminal", 300, 100, 800, 600, 1024))
{
stream.WriteLine(string.Format(commandFormat, runServerScript.RemotePath, String.Join(" ", scriptParams)));
var output = stream.Expect(Settings.InstallationStopPattern);
if (output.Contains(Settings.InstallationErrorPattern))
throw new Exception(output);
if (output.Contains(Settings.InstallationSuccessPattern))
InstallationProgress.ProgressText += output;
if (output.Contains(Settings.InstallationErrorPattern))
throw new Exception(output);
return output;
}
}
@ -397,6 +447,8 @@ namespace OneClickInstallation.Classes
{
foreach (var file in files)
{
if (!file.IsScriptFile) continue;
RunCommand(sshClient, string.Format("chmod +x {0}", file.RemotePath));
RunCommand(sshClient, string.Format("sed -i 's/\r$//' {0}", file.RemotePath));
}
@ -450,12 +502,21 @@ namespace OneClickInstallation.Classes
private class FileMap
{
public static readonly FileMap GetOsInfoScript = MakeSetupFileMap("get-os-info.sh", "tools");
public static readonly FileMap RunDockerScript = MakeSetupFileMap("run-docker.sh", "assets");
public static readonly FileMap CheckBindingsScript = MakeSetupFileMap("check-bindings.sh", "tools");
public static readonly FileMap CheckPortsScript = MakeSetupFileMap("check-ports.sh", "tools");
public static readonly FileMap CheckPreviousVersionScript = MakeSetupFileMap("check-previous-version.sh", "tools");
public static readonly FileMap GetAvailableVersionScript = MakeSetupFileMap("get-available-version.sh", "tools");
public static readonly FileMap GetOsInfoScript = MakeSetupFileMap("get-os-info.sh", "tools");
public static readonly FileMap LoginDockerScript = MakeSetupFileMap("login-docker.sh", "tools");
public static readonly FileMap MakeDirScript = MakeSetupFileMap("make-dir.sh", "tools");
public static readonly FileMap RunDockerScript = MakeSetupFileMap("run-docker.sh", "assets");
public static readonly FileMap MakeNetworkScript = MakeSetupFileMap("make-network.sh", "tools");
public static readonly FileMap PullImageScript = MakeSetupFileMap("pull-image.sh", "tools");
public static readonly FileMap RemoveContainerScript = MakeSetupFileMap("remove-container.sh", "tools");
public static readonly FileMap RunCommunityServerScript = MakeSetupFileMap("run-community-server.sh");
public static readonly FileMap RunControlPanelScript = MakeSetupFileMap("run-control-panel.sh");
public static readonly FileMap RunDocumentServerScript = MakeSetupFileMap("run-document-server.sh");
public static readonly FileMap RunMailServerScript = MakeSetupFileMap("run-mail-server.sh");
@ -463,17 +524,24 @@ namespace OneClickInstallation.Classes
public string RemoteDir { get; private set; }
public string FileName { get { return Path.GetFileName(LocalPath); } }
public string RemotePath { get { return Path.Combine(RemoteDir, FileName).Replace("\\", "/"); } }
public bool IsScriptFile { get; private set; }
public FileMap(string localPath, string remoteDir)
public FileMap(string localPath, string remoteDir, bool isScriptFile = true)
{
LocalPath = HttpContext.Current.Server.MapPath(localPath);
RemoteDir = remoteDir.TrimEnd('/').Replace("\\", "/");
IsScriptFile = isScriptFile;
}
private static FileMap MakeSetupFileMap(string script, string subFolder = "")
{
return new FileMap(Path.Combine("~/Executables", subFolder, script), Path.Combine(Settings.RemoteServerDir, "setup", subFolder));
}
public static FileMap MakeLicenseFileMap(string fileName, string moduleName)
{
return new FileMap(FileHelper.GetTmpFileVirtualPath(fileName), Path.Combine(Settings.RemoteServerDir, moduleName, "data"), false);
}
}
}
}

View File

@ -39,14 +39,7 @@
&.disabled {
cursor: default;
}
&.small {
height: 26px;
line-height: 26px;
font-size: 12px;
font-weight: normal;
text-transform: none;
pointer-events: none;
}
&.green {
@ -62,45 +55,8 @@
}
&.disabled {
background: #b7b7b7;
}
}
&.gray {
background: #f4f4f4;
border-color: #e0e0e0;
border-style: solid;
border-width: 1px;
color: #4c4c4c;
padding: 0 19px;
height: 46px;
&:hover {
border-color: #c5c5c5;
}
&:active {
background: #eaeaea;
border-color: #c5c5c5;
}
&.disabled {
background: #f4f4f4;
border-color: #e0e0e0;
color: #999999;
}
}
&.dark {
background: #888888;
color: #ffffff;
&:hover {
background: #909090;
}
&:active {
background: #808080;
background: #66bb6a;
color: #b5dbb7;
}
}
@ -115,18 +71,10 @@
&:active {
background: #444444;
}
}
&.blue {
background: #7a8ab1;
color: #ffffff;
&:hover {
background: #8494bb;
}
&:active {
background: #667bae;
&.disabled {
background: #4c4c4c;
color: #999999;
}
}
}

View File

@ -121,6 +121,11 @@ input[type="password"]
{
background-position: -82px -135px;
}
.label
{
color: #999999;
}
}
&.checked
@ -160,6 +165,11 @@ input[type="password"]
&.disabled
{
cursor: default;
.label
{
color: #999999;
}
}
&.checked
@ -187,4 +197,99 @@ input[type="password"]
padding: 0 8px 1px;
}
}
}
}
.custom-select {
border-color: #c1c1c1;
border-width: 1px;
border-style: solid;
display: block;
margin: 0;
padding: 10px 14px;
height: 26px;
line-height: 26px;
font-size: 16px;
cursor: pointer;
&.error {
border-color: #bf3703;
}
&.disabled {
background-color: #f4f4f4;
}
&.single
{
.borderRadius(3px);
}
&.group-top
{
border-bottom-color: #f3f3f3;
.borderTopRadius(3px);
}
&.group-center
{
border-top-color: #f3f3f3;
border-bottom-color: #f3f3f3;
}
&.group-bottom
{
border-top-color: #f3f3f3;
.borderBottomRadius(3px);
}
.custom-select-value {
border: medium none;
height: 22px;
width: 90%;
padding: 0;
}
.custom-select-switch {
float: right;
width: 0;
height: 0;
margin-top: 11px;
border-style: solid;
border-width: 4px 4px 0 4px;
border-color: #4c4c4c transparent transparent transparent;
}
.custom-select-options {
display: none;
position: absolute;
padding: 5px;
background-color: white;
border: 1px solid #c1c1c1;
.borderRadius(2px);
.boxShadow(1px, 1px, 8px, rgba(0,0,0,.2));
z-index: 1000;
.custom-select-options-inner {
max-height: 200px;
padding-right: 20px;
overflow-y: auto;
.custom-select-option {
display: block;
text-decoration: none;
padding: 2px 14px 2px 4px;
min-width: 50px;
color: #666666;
&:hover {
background-color: #e9e9e9;
cursor: pointer;
}
&.selected {
color: #2e94c9;
}
}
}
}
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.0 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

After

Width:  |  Height:  |  Size: 2.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.3 KiB

After

Width:  |  Height:  |  Size: 6.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.9 KiB

After

Width:  |  Height:  |  Size: 5.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 465 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 431 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 585 B

View File

@ -61,14 +61,14 @@
display: none;
}
.bottom-indent
.bottom-indent-small
{
margin-bottom: 24px;
margin-bottom: 18px;
}
.bottom-indent-middle
.bottom-indent
{
margin-bottom: 36px;
margin-bottom: 30px;
}
.bottom-indent-big
@ -190,14 +190,14 @@
{
.icon
{
background-position: -32px -56px;
background-position: -31px -57px;
}
&.selected
{
.icon
{
background-position: -6px -56px;
background-position: -5px -57px;
}
}
@ -205,31 +205,7 @@
{
.icon
{
background-position: -58px -56px;
}
}
}
.setup
{
.icon
{
background-position: -32px -82px;
}
&.selected
{
.icon
{
background-position: -6px -82px;
}
}
&.disabled
{
.icon
{
background-position: -58px -82px;
background-position: -57px -57px;
}
}
}
@ -238,14 +214,14 @@
{
.icon
{
background-position: -32px -108px;
background-position: -31px -83px;
}
&.selected
{
.icon
{
background-position: -6px -108px;
background-position: -5px -83px;
}
}
@ -253,7 +229,31 @@
{
.icon
{
background-position: -58px -108px;
background-position: -57px -83px;
}
}
}
.setup
{
.icon
{
background-position: -31px -109px;
}
&.selected
{
.icon
{
background-position: -5px -109px;
}
}
&.disabled
{
.icon
{
background-position: -57px -109px;
}
}
}
@ -391,16 +391,16 @@
border-bottom: 1px solid #c1c1c1;
font-size: 18px;
font-weight: 100;
height: 24px;
line-height: 24px;
padding: 12px 24px;
height: 14px;
line-height: 14px;
padding: 30px;
}
.popup-error {
float: left;
margin-right: 8px;
height: 25px;
width: 25px;
margin: -5px 8px 0 0;
height: 26px;
width: 26px;
background-image: url("images/sprite.png");
background-position: 0 0;
background-repeat: no-repeat;
@ -408,23 +408,31 @@
.popup-warning {
float: left;
margin-right: 8px;
height: 25px;
width: 25px;
margin: -5px 8px 0 0;
height: 26px;
width: 26px;
background-image: url("images/sprite.png");
background-position: -52px 0;
background-repeat: no-repeat;
}
.popup-close {
float: right;
font-size: 14px;
font-weight: bold;
background-image: url("images/sprite.png");
background-position: 0 -182px;
background-repeat: no-repeat;
cursor: pointer;
float: right;
height: 26px;
margin: -5px 0 0 8px;
width: 26px;
}
.popup-close:hover {
background-position: -26px -182px;
}
.popup-body {
padding: 24px;
padding: 30px;
}
}
@ -436,13 +444,13 @@
background-image: url("images/step.png");
background-repeat: no-repeat;
background-position: center center;
height: 70px;
height: 100px;
}
.install-step {
display: inline-block;
float: left;
text-align: center;
width: 202px;
width: 33%;
}
.requirements-box {
@ -548,40 +556,6 @@
}
}
.cp-feature {
background-color: #f4f4f4;
border: 1px solid #c5c5c5;
height: 96px;
text-align: center;
width: 120px;
.borderRadius(3px);
.icon {
height: 42px;
width: 42px;
margin: 18px auto 4px;
background-image: url("images/cp_features.png");
background-repeat: no-repeat;
background-position: center center;
&.https {
background-position: center -308px;
}
&.audit {
background-position: center -176px;
}
&.backup {
background-position: center 0;
}
&.update {
background-position: center -132px;
}
}
}
.git {
background-image: url("images/sprite.png");
background-repeat: no-repeat;
@ -589,15 +563,4 @@
height: 26px;
line-height: 26px;
padding-left: 32px;
}
.coming-soon {
background-image: url("images/coming_soon.png");
background-position: center center;
background-repeat: no-repeat;
display: inline-block;
height: 21px;
margin-left: 4px;
margin-top: 3px;
width: 87px;
}

View File

@ -17,6 +17,8 @@
*
*/
@import "vars";
.toast-title {
font-weight: bold;
}
@ -28,12 +30,11 @@
.toast-message a,
.toast-message label {
color: #ffffff;
color: #000;
}
.toast-message a:hover {
color: #cccccc;
text-decoration: none;
text-decoration: underline;
}
.toast-top-full-width {
@ -54,13 +55,13 @@
}
.toast-top-right {
top: 142px;
right: 12px;
top: 75px;
}
.toast-bottom-right {
right: 12px;
bottom: 102px;
bottom: 12px;
}
.toast-bottom-left {
@ -72,61 +73,22 @@
position: fixed;
z-index: 999999;
}
#toast-container * {
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
.toast-container {
width: 100%;
}
#toast-container > div {
margin: 0 0 6px;
padding: 15px 15px 15px 50px;
width: 300px;
-moz-border-radius: 3px 3px 3px 3px;
-webkit-border-radius: 3px 3px 3px 3px;
border-radius: 3px 3px 3px 3px;
#toast-container > div,
.toast-container > div,
.toast-popup-container > div {
background-position: 15px center;
background-repeat: no-repeat;
-moz-box-shadow: 0 0 12px #999999;
-webkit-box-shadow: 0 0 12px #999999;
box-shadow: 0 0 12px #999999;
color: #ffffff;
opacity: 0.8;
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80);
filter: alpha(opacity=80);
.borderRadius(3px);
color: #000;
margin: 0 0 6px;
padding: 15px 15px 15px 50px;
}
#toast-container > :hover {
-moz-box-shadow: 0 0 12px #000000;
-webkit-box-shadow: 0 0 12px #000000;
box-shadow: 0 0 12px #000000;
opacity: 1;
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
filter: alpha(opacity=100);
cursor: pointer;
}
#toast-container > .toast-info {
background-image: url("") !important;
}
#toast-container > .toast-error {
background-image: url("") !important;
}
#toast-container > .toast-success {
background-image: url("") !important;
}
#toast-container > .toast-warning {
background-image: url("") !important;
}
#toast-container.toast-top-full-width > div,
#toast-container.toast-bottom-full-width > div {
width: 96%;
margin: auto;
#toast-container > div,
.toast-popup-container > div {
width: 300px;
}
.toast {
@ -134,20 +96,76 @@
}
.toast-success {
background-color: #51a351;
background-color: #cae796;
}
.toast-error {
background-color: #bd362f;
background-color: #ffbfaa;
}
.toast-info {
background-color: #2f96b4;
background-color: #f1da92;
}
.toast-warning {
background-color: #f89406;
background-color: #F89406;
}
#toast-container .toast-success:hover {
background-color: #bcdf7e;
}
#toast-container .toast-error:hover {
background-color: #ffa98d;
}
#toast-container .toast-info:hover {
background-color: #eed27b;
}
#toast-container > :hover {
.boxShadow(1px, 2px, 4px, #D1D1D1);
cursor: pointer;
}
#toast-container > .toast-info,
.toast-container > .toast-info,
.toast-popup-container > .toast-info {
background-image: url("images/toast_icon03.png");
}
#toast-container > .toast-error,
.toast-container > .toast-error,
.toast-popup-container > .toast-error {
background-image: url("images/toast_icon01.png");
}
#toast-container > .toast-success,
.toast-container > .toast-success,
.toast-popup-container > .toast-success {
background-image: url("images/toast_icon02.png");
}
#toast-container > .toast-warning,
.toast-container > .toast-warning,
.toast-popup-container > .toast-warning {
background-image: url("images/toast_icon01.png");
}
/*Popup Toasts*/
.toast-popup-container .toast {
width: auto;
padding: 14px 0 14px 40px;
background-position: 8px center;
.borderRadius(0);
margin-top:6px;
}
.toast-popup-container .toast .toast-message {
color: #333;
}
/*Responsive Design*/
@media all and (max-width: 240px) {
@ -176,4 +194,11 @@
padding: 15px 15px 15px 50px;
width: 300px;
}
}
/* overrides */
#toast-container.toast-top-full-width > div,
#toast-container.toast-bottom-full-width > div {
width: 100%;
margin: 1px 0 1px 0;
}

View File

@ -18,10 +18,16 @@
*/
using System;
using System.Collections.Specialized;
using System.Globalization;
using System.IO;
using System.Net;
using System.Net.Mail;
using System.Runtime.InteropServices;
using System.Text;
using System.Text.RegularExpressions;
using System.Web.Mvc;
using ASC.Core.Billing;
using OneClickInstallation.Classes;
using OneClickInstallation.Helpers;
using OneClickInstallation.Models;
using OneClickInstallation.Resources;
@ -41,12 +47,16 @@ namespace OneClickInstallation.Controllers
}
}
public ActionResult Index()
public ActionResult Index(string id)
{
var enterprise = !string.IsNullOrEmpty(id) && id.ToLowerInvariant() == "enterprise";
ConnectionSettingsModel connectionSettings = null;
InstallationComponentsModel availableComponents = CacheHelper.GetAvailableComponents(enterprise);
InstallationComponentsModel installedComponents = null;
InstallationComponentsModel selectedComponents = null;
InstallationProgressModel installationProgress = null;
OsInfo osInfo = null;
if (!string.IsNullOrEmpty(UserId))
{
@ -57,18 +67,27 @@ namespace OneClickInstallation.Controllers
installedComponents = CacheHelper.GetInstalledComponents(UserId);
selectedComponents = CacheHelper.GetSelectedComponents(UserId);
installationProgress = CacheHelper.GetInstallationProgress(UserId);
osInfo = CacheHelper.GetOsInfo(UserId);
}
else
{
CookieHelper.ClearCookie();
CacheHelper.ClearCache(UserId);
CacheHelper.ClearUserCache(UserId);
}
}
ViewBag.ConnectionSettings = GetJsonString(connectionSettings);
ViewBag.AvailableComponents = GetJsonString(availableComponents);
ViewBag.InstalledComponents = GetJsonString(installedComponents);
ViewBag.SelectedComponents = GetJsonString(selectedComponents);
ViewBag.InstallationProgress = GetJsonString(installationProgress);
ViewBag.OsInfo = GetJsonString(osInfo);
ViewBag.Enterprise = enterprise;
if (!string.IsNullOrEmpty(Settings.CacheKey) && Request.Params["cache"] == Settings.CacheKey)
{
CacheHelper.ClearCache();
}
return View();
}
@ -78,16 +97,23 @@ namespace OneClickInstallation.Controllers
{
try
{
if (Request.Files.Count <= 0)
{
if (Request.Files == null || Request.Files.Count <= 0)
throw new Exception(OneClickCommonResource.ErrorFilesNotTransfered);
var savedFileName = FileHelper.SaveFile(Request.Files[0]);
bool isLicenseFile;
if (Boolean.TryParse(Request.Params["license"], out isLicenseFile))
{
if (isLicenseFile) ValidateLicenseFile(savedFileName);
}
return Json(new
{
success = true,
message = OneClickCommonResource.FileUploadedMsg,
fileName = FileHelper.SaveFile(Request.Files[0])
fileName = savedFileName
});
}
catch (Exception ex)
@ -104,27 +130,41 @@ namespace OneClickInstallation.Controllers
}
[HttpPost]
public JsonResult Connect(ConnectionSettingsModel connectionSettings)
public JsonResult Connect(ConnectionSettingsModel connectionSettings, RequestInfoModel requestInfo)
{
try
{
InstallationComponentsModel installedComponents = null;
InstallationComponentsModel selectedComponents = null;
InstallationProgressModel installationProgress = null;
OsInfo osInfo = null;
if (connectionSettings != null)
{
installedComponents = SshHelper.Connect(UserId, connectionSettings);
if (connectionSettings.Enterprise)
{
if (string.IsNullOrEmpty(connectionSettings.LicenseKey))
throw new ArgumentException("connectionSettings.licenseKey");
if (connectionSettings.LicenseKey == Settings.TrialFileName && requestInfo == null)
throw new ArgumentNullException("requestInfo");
}
var data = SshHelper.Connect(UserId, connectionSettings);
osInfo = data.Item1;
installedComponents = data.Item2;
installationProgress = CacheHelper.GetInstallationProgress(UserId);
selectedComponents = CacheHelper.GetSelectedComponents(UserId);
CacheHelper.SetConnectionSettings(UserId, connectionSettings);
CacheHelper.SetInstalledComponents(UserId, installedComponents);
CacheHelper.SetRequestInfo(UserId, requestInfo);
}
else
{
CookieHelper.ClearCookie();
CacheHelper.ClearCache(UserId);
CacheHelper.ClearUserCache(UserId);
}
return Json(new
@ -134,7 +174,8 @@ namespace OneClickInstallation.Controllers
connectionSettings = GetJsonString(connectionSettings),
installedComponents = GetJsonString(installedComponents),
installationProgress = GetJsonString(installationProgress),
selectedComponents = GetJsonString(selectedComponents)
selectedComponents = GetJsonString(selectedComponents),
osInfo = GetJsonString(osInfo)
});
}
catch (Exception ex)
@ -151,27 +192,26 @@ namespace OneClickInstallation.Controllers
}
[HttpPost]
public JsonResult StartInstall(ConnectionSettingsModel connectionSettings, InstallationComponentsModel installationComponents)
public JsonResult StartInstall(InstallationComponentsModel installationComponents)
{
try
{
var connectionSettings = CacheHelper.GetConnectionSettings(UserId);
var installedComponents = CacheHelper.GetInstalledComponents(UserId);
if (installedComponents != null)
return Json(new
{
success = false,
message = OneClickHomePageResource.ExistVersionErrorText
});
if (connectionSettings.Enterprise && connectionSettings.LicenseKey == Settings.TrialFileName && !string.IsNullOrEmpty(Settings.LicenseUrl))
{
if (installedComponents != null && installedComponents.LicenseFileExist)
throw new Exception(OneClickCommonResource.ErrorLicenseFileExist);
if (!installationComponents.CommunityServer || !installationComponents.DocumentServer)
return Json(new
{
success = false,
message = OneClickCommonResource.ErrorRequiredComponents
});
connectionSettings = RequestLicenseFile(connectionSettings, CacheHelper.GetRequestInfo(UserId));
}
if (installationComponents.MailServer && !ValidateDomainName(installationComponents.MailDomain))
var mailServerAlreadyInstalled = installedComponents != null &&
!string.IsNullOrEmpty(installedComponents.MailServerVersion);
if (!mailServerAlreadyInstalled && !string.IsNullOrEmpty(installationComponents.MailServerVersion) &&
!ValidateDomainName(installationComponents.MailDomain))
return Json(new
{
success = false,
@ -179,6 +219,7 @@ namespace OneClickInstallation.Controllers
});
CacheHelper.SetSelectedComponents(UserId, installationComponents);
CacheHelper.SetInstallationProgress(UserId, new InstallationProgressModel());
SshHelper.StartInstallation(UserId, connectionSettings, installationComponents);
@ -198,10 +239,18 @@ namespace OneClickInstallation.Controllers
CacheHelper.SetSelectedComponents(UserId, null);
CacheHelper.SetInstallationProgress(UserId, null);
var code = 0;
if (ex is ExternalException)
{
Int32.TryParse(Regex.Match(ex.Message, @"[\d+]").Value, out code);
}
return Json(new
{
success = false,
message = ex.Message
message = ex.Message,
errorCode = code > 0 ? "External" + code : "unknown"
});
}
}
@ -233,7 +282,7 @@ namespace OneClickInstallation.Controllers
errorCode = 0,
errorMessage = string.Empty,
progressText = Settings.DebugMode ? progress.ProgressText : string.Empty,
installedComponents = GetJsonString(progress.IsCompleted ? CacheHelper.GetInstalledComponents(UserId) : null),
installedComponents = GetJsonString(progress.IsCompleted ? CacheHelper.GetInstalledComponents(UserId) : null)
}, JsonRequestBehavior.AllowGet);
}
@ -247,7 +296,8 @@ namespace OneClickInstallation.Controllers
step = (int)progress.Step,
errorCode = GetErrorCode(progress.ErrorMessage),
errorMessage = progress.ErrorMessage,
progressText = progress.ProgressText
progressText = progress.ProgressText,
installedComponents = GetJsonString(CacheHelper.GetInstalledComponents(UserId))
}, JsonRequestBehavior.AllowGet);
}
catch (Exception ex)
@ -264,60 +314,12 @@ namespace OneClickInstallation.Controllers
step = (int)progress.Step,
errorCode = 0,
errorMessage = ex.Message,
progressText = progress.ProgressText
progressText = progress.ProgressText,
installedComponents = GetJsonString(CacheHelper.GetInstalledComponents(UserId))
}, JsonRequestBehavior.AllowGet);
}
}
[HttpPost]
public JsonResult SendEmail(string email)
{
try
{
var targetEmail = new MailAddress(email);
var emailSender = Settings.EmailSender;
if(emailSender == null)
throw new Exception(OneClickCommonResource.EmailSenderIsNull);
var mail = new MailMessage();
var client = new SmtpClient
{
Host = emailSender.Host,
Port = emailSender.Port,
Timeout = 10000,
EnableSsl = emailSender.EnableSsl,
DeliveryMethod = SmtpDeliveryMethod.Network,
UseDefaultCredentials = false,
Credentials = new NetworkCredential(emailSender.Email.Split('@')[0], emailSender.Password)
};
mail.To.Add(new MailAddress(Settings.SupportEmail));
mail.From = new MailAddress(emailSender.Email);
mail.Subject = OneClickJsResource.NotyfyEmailSubject;
mail.Body = string.Format(OneClickJsResource.NotyfyEmailBody, targetEmail.Address);
client.Send(mail);
return Json(new
{
success = true,
message = OneClickJsResource.EmailSendedMsg,
});
}
catch (Exception ex)
{
LogManager.GetLogger("ASC").Error(ex.Message, ex);
return Json(new
{
success = false,
message = ex.Message
});
}
}
private string GetJsonString(object obj)
{
@ -354,5 +356,59 @@ namespace OneClickInstallation.Controllers
var regex = new Regex(@"(?=^.{5,254}$)(^(?:(?!\d+\.)[a-zA-Z0-9_\-]{1,63}\.?)+\.(?:[a-zA-Z]{2,})$)", RegexOptions.Compiled | RegexOptions.IgnoreCase);
return regex.IsMatch(domainName);
}
private void ValidateLicenseFile(string fileName)
{
var filePath = FileHelper.GetFile(fileName);
var ext = Path.GetExtension(filePath);
if (string.IsNullOrEmpty(ext) || ext.ToLower() != ".lic")
{
FileHelper.RemoveFile(filePath);
throw new Exception(OneClickCommonResource.ErrorFileExt);
}
//TODO: LicenseReader.CheckValid new .dll
//if (LicenseReader.CheckValid(filePath)) return;
//FileHelper.RemoveFile(filePath);
//throw new Exception(OneClickCommonResource.ErrorLicenseFileNotValid);
}
private ConnectionSettingsModel RequestLicenseFile(ConnectionSettingsModel connectionSettings, RequestInfoModel requestInfo)
{
if(requestInfo == null)
throw new Exception(OneClickCommonResource.ErrorRequestInfoIsNull);
using (var client = new WebClient())
{
var values = new NameValueCollection();
values["Host"] = connectionSettings.Host;
values["FName"] = requestInfo.Name;
values["Email"] = requestInfo.Email;
values["Phone"] = requestInfo.Phone;
values["CompanyName"] = requestInfo.CompanyName;
values["CompanySize"] = requestInfo.CompanySize.ToString(CultureInfo.InvariantCulture);
values["Position"] = requestInfo.Position;
var response = client.UploadValues(Settings.LicenseUrl, values);
var responseString = Encoding.Default.GetString(response).Replace("\"", string.Empty);
if(responseString.Contains("error"))
throw new ExternalException(responseString);
var licenseFileName = FileHelper.SaveFile(responseString);
connectionSettings.LicenseKey = licenseFileName;
CacheHelper.SetConnectionSettings(UserId, connectionSettings);
return connectionSettings;
}
}
}
}

View File

@ -24,9 +24,9 @@ using System.Globalization;
using System.Resources;
using System.Text;
using System.Web.Mvc;
using Newtonsoft.Json;
using OneClickInstallation.Helpers;
using OneClickInstallation.Resources;
using TMResourceData;
namespace OneClickInstallation.Controllers
{
@ -82,22 +82,13 @@ namespace OneClickInstallation.Controllers
var script = string.Empty;
foreach (var pair in resources)
{
var set = pair.Item1.GetResourceSet(new CultureInfo(culture), true, true);
var baseSet = pair.Item1.GetResourceSet(new CultureInfo(LangHelper.DefaultLanguage), true, true);
var dbManager = pair.Item1 as DBResourceManager;
var baseNeutral = baseSet;
if (dbManager != null)
{
baseNeutral = dbManager.GetBaseNeutralResourceSet();
}
var baseSet = pair.Item1.GetResourceSet(CultureInfo.InvariantCulture, true, true);
var js = new StringBuilder(pair.Item2 + "={");
foreach (DictionaryEntry entry in baseNeutral)
foreach (DictionaryEntry entry in baseSet)
{
var value = set.GetString((string)entry.Key) ?? baseSet.GetString((string)entry.Key) ?? baseNeutral.GetString((string)entry.Key) ?? string.Empty;
js.AppendFormat("\"{0}\":\"{1}\",", entry.Key, (value).Replace("\"", "\\\""));
var key = (string)entry.Key;
var value = pair.Item1.GetString(key, new CultureInfo(culture)) ?? string.Empty;
js.AppendFormat("\"{0}\":{1},", entry.Key, JsonConvert.SerializeObject(value));
}
script += js.ToString();

View File

@ -13,172 +13,171 @@
DIST=${1}
REV=${2}
ARCH_TYPE=${3}
KERNEL=${4}
IS_REBOOT=${5:-false}
EXIT_STATUS=-1;
EXIT_NOT_SUPPORTED_OS_STATUS=10;
KERNEL=${3}
ARCH_TYPE=${4}
command_exists () {
type "$1" &> /dev/null ;
check_os_info () {
if [[ -z ${DIST} || -z ${REV} || -z ${KERNEL} || -z ${ARCH_TYPE} ]]; then
echo "Not supported OS"
echo "INSTALLATION-STOP-ERROR[2]"
exit 0;
fi
if [ "${ARCH_TYPE}" != "x86_64" ]; then
echo "Currently only supports 64bit OS's";
echo "INSTALLATION-STOP-ERROR[1]"
exit 0;
fi
}
if command_exists docker ; then
echo "docker is already installed."
echo "INSTALLATION-STOP-SUCCESS"
exit 0;
fi
check_kernel () {
MIN_NUM_ARR=(3 10 0);
CUR_NUM_ARR=();
CUR_STR_ARR=$(echo $KERNEL | grep -Po "[0-9]+\.[0-9]+\.[0-9]+" | tr "." " ");
for CUR_STR_ITEM in $CUR_STR_ARR
do
CUR_NUM_ARR=(${CUR_NUM_ARR[@]} $CUR_STR_ITEM)
done
if [ "${ARCH_TYPE}" != "x86_64" ]; then
echo "Currently only supports 64bit OS's";
echo "INSTALLATION-STOP-ERROR[1]"
exit 0;
fi
INDEX=0;
REV_PARTS=(${REV//\./ })
REV=${REV_PARTS[0]}
if [ "${DIST}" == "Ubuntu" ]; then
if [ "${REV}" -ge "14" ]; then
sudo apt-get -y update
sudo apt-get -y upgrade
sudo apt-get -y -q --force-yes install curl
sudo curl -sSL https://get.docker.com/ | sh
elif [ "${REV}" -eq "13" ]; then
sudo apt-get -y update
sudo apt-get -y upgrade
sudo apt-get -y install linux-image-extra-`uname -r`
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys 36A1D7869245C8950F966E92D8576A8BA88D21E9
sudo sh -c "echo deb http://get.docker.com/ubuntu docker main > /etc/apt/sources.list.d/docker.list"
sudo apt-get -y update
sudo apt-get -y install lxc-docker
elif [ "${REV}" -eq "12" ]; then
# install the backported kernel
sudo apt-get -y update
sudo apt-get -y -q --force-yes install linux-image-generic-lts-trusty
# reboot
if [ "${IS_REBOOT}" == "false" ] ; then
echo "INSTALLATION-STOP-REBOOT"
while [[ $INDEX -lt 3 ]]; do
if [ ${CUR_NUM_ARR[INDEX]} -lt ${MIN_NUM_ARR[INDEX]} ]; then
echo "Not supported OS Kernel"
echo "INSTALLATION-STOP-ERROR[7]"
exit 0;
elif [ ${CUR_NUM_ARR[INDEX]} -gt ${MIN_NUM_ARR[INDEX]} ]; then
INDEX=3
fi
sudo apt-get -y -q --force-yes update
sudo apt-get -y -q --force-yes install wget
sudo wget -qO- https://get.docker.com/ | sh
(( INDEX++ ))
done
}
command_exists () {
type "$1" &> /dev/null;
}
check_docker_version () {
MIN_NUM_ARR=(1 10 0);
CUR_NUM_ARR=();
CUR_STR_ARR=$(docker -v | grep -Po "[0-9]+\.[0-9]+\.[0-9]+" | tr "." " ");
for CUR_STR_ITEM in $CUR_STR_ARR
do
CUR_NUM_ARR=(${CUR_NUM_ARR[@]} $CUR_STR_ITEM)
done
NEED_UPDATE="false"
INDEX=0;
while [[ $INDEX -lt 3 ]]; do
if [ ${CUR_NUM_ARR[INDEX]} -lt ${MIN_NUM_ARR[INDEX]} ]; then
NEED_UPDATE="true"
INDEX=3
elif [ ${CUR_NUM_ARR[INDEX]} -gt ${MIN_NUM_ARR[INDEX]} ]; then
INDEX=3
fi
(( INDEX++ ))
done
echo "$NEED_UPDATE"
}
uninstall_docker () {
if [ "${DIST}" == "Ubuntu" ] || [ "${DIST}" == "Debian" ]; then
sudo apt-get -y autoremove --purge docker-engine
elif [[ "${DIST}" == CentOS* ]] || [ "${DIST}" == "Red Hat Enterprise Linux Server" ]; then
sudo yum -y remove docker-engine.x86_64
elif [ "${DIST}" == "SuSe" ]; then
sudo zypper rm -y docker
elif [ "${DIST}" == "Fedora" ]; then
sudo dnf -y remove docker-engine.x86_64
else
EXIT_STATUS=${EXIT_NOT_SUPPORTED_OS_STATUS};
echo "Not supported OS"
echo "INSTALLATION-STOP-ERROR[2]"
exit 0;
fi
elif [ "${DIST}" == "Debian" ]; then
if [ "${REV}" -ge "8" ]; then
}
install_docker () {
if [ "${DIST}" == "Ubuntu" ] || [ "${DIST}" == "Debian" ]; then
sudo apt-get -y update
sudo apt-get -y upgrade
sudo apt-get -y -q --force-yes install curl
sudo apt-get -y -q install curl
sudo curl -sSL https://get.docker.com/ | sh
elif [ "${REV}" -eq "7" ]; then
echo "deb http://http.debian.net/debian wheezy-backports main" >> /etc/apt/sources.list
sudo apt-get -y update
sudo apt-get -y upgrade
sudo apt-get -y -q --force-yes install curl
sudo apt-get -y -q --force-yes install -t wheezy-backports linux-image-amd64
# reboot
if [ "${IS_REBOOT}" == "false" ] ; then
echo "INSTALLATION-STOP-REBOOT"
exit 0;
fi
elif [[ "${DIST}" == CentOS* ]] || [ "${DIST}" == "Red Hat Enterprise Linux Server" ]; then
curl -sSL https://get.docker.com/ | sh
else
EXIT_STATUS=${EXIT_NOT_SUPPORTED_OS_STATUS};
fi
elif [[ "${DIST}" == CentOS* ]] || [ "${DIST}" == "Red Hat Enterprise Linux Server" ]; then
if [ "${REV}" -ge "7" ]; then
if [ "${DIST}" == "Red Hat Enterprise Linux Server" ]; then
sudo yum -y install yum-utils
sudo yum-config-manager --enable rhui-REGION-rhel-server-extras
fi
sudo yum -y update
sudo yum -y upgrade
sudo yum -y install docker
sudo setenforce 0
sudo systemctl stop firewalld.service
sudo systemctl disable firewalld.service
sudo systemctl start docker.service
sudo systemctl enable docker.service
elif [ "${REV}" -eq "6" ]; then
sudo yum -y update
sudo yum -y upgrade
sudo yum -y install epel-release
sudo yum -y install docker-io
sudo yum -y install curl
sudo curl -fsSL https://get.docker.com/ | sh
sudo service docker start
sudo chkconfig docker on
else
EXIT_STATUS=${EXIT_NOT_SUPPORTED_OS_STATUS};
fi
elif [ "${DIST}" == "SuSe" ]; then
if [ "${REV}" -ge "13" ]; then
sudo zypper ar -f http://download.opensuse.org/repositories/Virtualization/openSUSE_13.1/ Virtualization
sudo zypper --non-interactive in docker
elif [ "${DIST}" == "SuSe" ]; then
sudo zypper in -y docker
sudo systemctl start docker
sudo systemctl enable docker
elif [ "${REV}" -ge "12" ]; then
sudo zypper ar -f http://download.opensuse.org/repositories/Virtualization/openSUSE_12.3/ Virtualization
sudo zypper --non-interactive in docker
sudo systemctl start docker
sudo systemctl enable docker
else
EXIT_STATUS=${EXIT_NOT_SUPPORTED_OS_STATUS};
fi
elif [ "${DIST}" == "Fedora" ]; then
if [ "${REV}" -ge "21" ]; then
elif [ "${DIST}" == "Fedora" ]; then
sudo dnf -y update
sudo yum -y update
sudo yum -y upgrade
sudo yum -y install docker
sudo setenforce 0
sudo systemctl start docker
sudo systemctl enable docker
elif [ "${REV}" -eq "20" ]; then
sudo yum -y update
sudo yum -y upgrade
sudo yum -y remove docker
sudo yum -y install docker-io
sudo yum -y install curl
sudo curl -fsSL https://get.docker.com/ | sh
sudo systemctl start docker
sudo systemctl enable docker
else
EXIT_STATUS=${EXIT_NOT_SUPPORTED_OS_STATUS};
echo "Not supported OS"
echo "INSTALLATION-STOP-ERROR[2]"
exit 0;
fi
else
EXIT_STATUS=${EXIT_NOT_SUPPORTED_OS_STATUS};
fi
if ! command_exists docker ; then
echo "Error while installing docker"
echo "INSTALLATION-STOP-ERROR[6]"
exit 0;
fi
echo "Docker successfully installed"
echo "INSTALLATION-STOP-SUCCESS"
exit 0;
}
if [ ${EXIT_STATUS} -eq ${EXIT_NOT_SUPPORTED_OS_STATUS} ]; then
echo "Not supported OS"
echo "INSTALLATION-STOP-ERROR[2]"
exit 0;
fi
check_os_info
check_kernel
if command_exists docker ; then
echo "docker successfully installed."
echo "INSTALLATION-STOP-SUCCESS"
exit 0;
fi
NEED_UPDATE=$(check_docker_version);
echo "error while installing docker."
echo "INSTALLATION-STOP-ERROR[6]"
if [ "$NEED_UPDATE" == "true" ]; then
uninstall_docker
install_docker
else
echo "Docker successfully installed"
echo "INSTALLATION-STOP-SUCCESS"
exit 0;
fi
else
install_docker
fi

View File

@ -14,18 +14,21 @@
COMMUNITY_CONTAINER_NAME="onlyoffice-community-server";
DOCUMENT_CONTAINER_NAME="onlyoffice-document-server";
MAIL_CONTAINER_NAME="onlyoffice-mail-server";
CONTROLPANEL_CONTAINER_NAME="onlyoffice-controlpanel";
CONTROLPANEL_CONTAINER_NAME="onlyoffice-control-panel";
COMMUNITY_IMAGE_NAME="onlyoffice/communityserver";
DOCUMENT_IMAGE_NAME="onlyoffice/documentserver";
COMMUNITY_IMAGE_NAME="onlyoffice4enterprise/communityserver-ee";
DOCUMENT_IMAGE_NAME="onlyoffice4enterprise/documentserver-ee";
MAIL_IMAGE_NAME="onlyoffice/mailserver";
CONTROLPANEL_IMAGE_NAME="onlyoffice/controlpanel";
CONTROLPANEL_IMAGE_NAME="onlyoffice4enterprise/controlpanel-ee";
COMMUNITY_VERSION="";
DOCUMENT_VERSION="";
MAIL_VERSION="";
CONTROLPANEL_VERSION="";
MAIL_SERVER_HOST="";
DOCUMENT_SERVER_HOST="";
LICENSE_FILE_PATH="";
MAIL_DOMAIN_NAME="";
@ -50,6 +53,7 @@ PULL_DOCUMENT_SERVER="false"
PULL_MAIL_SERVER="false"
PULL_CONTROLPANEL="false"
USE_AS_EXTERNAL_SERVER="false"
while [ "$1" != "" ]; do
case $1 in
@ -110,6 +114,20 @@ while [ "$1" != "" ]; do
fi
;;
-dip | --documentserverip )
if [ "$2" != "" ]; then
DOCUMENT_SERVER_HOST=$2
shift
fi
;;
-mip | --mailserverip )
if [ "$2" != "" ]; then
MAIL_SERVER_HOST=$2
shift
fi
;;
-cv | --communityversion )
if [ "$2" != "" ]; then
COMMUNITY_VERSION=$2
@ -242,7 +260,14 @@ while [ "$1" != "" ]; do
shift
fi
;;
-es | --useasexternalserver )
if [ "$2" != "" ]; then
USE_AS_EXTERNAL_SERVER=$2
shift
fi
;;
-? | -h | --help )
echo " Usage $0 [PARAMETER] [[PARAMETER], ...]"
echo " Parameters:"
@ -256,7 +281,9 @@ while [ "$1" != "" ]; do
echo " -cpi, --controlpanelimage control panel image name"
echo " -cv, --communityversion community version"
echo " -dv, --documentversion document version"
echo " -dip, --documentserverip document server ip"
echo " -mv, --mailversion mail version"
echo " -mip, --mailserverip mail server ip"
echo " -cpv, --controlpanelversion control panel version"
echo " -lf, --licensefile license file path"
echo " -md, --maildomain mail domail name"
@ -273,6 +300,7 @@ while [ "$1" != "" ]; do
echo " -pds, --pulldocumentserver pull document server (true|false)"
echo " -pms, --pullmailserver pull mail server (true|false)"
echo " -pcp, --pullcontrolpanel pull control panel (true|false)"
echo " -es, --useasexternalserver use as external server (true|false)"
echo " -?, -h, --help this help"
echo
exit 0
@ -710,6 +738,7 @@ check_bindings () {
install_document_server () {
DOCUMENT_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${DOCUMENT_CONTAINER_NAME});
DOCUMENT_SERVER_ADDITIONAL_PORTS="";
if [[ -n ${DOCUMENT_SERVER_ID} ]]; then
if [ "$UPDATE" == "true" ]; then
@ -726,7 +755,10 @@ install_document_server () {
DOCUMENT_VERSION=$(get_available_version "$DOCUMENT_IMAGE_NAME");
fi
sudo docker run -i -t -d --restart=always --name ${DOCUMENT_CONTAINER_NAME} \
if [ "${USE_AS_EXTERNAL_SERVER}" == "true" ]; then
DOCUMENT_SERVER_ADDITIONAL_PORTS="-p 80:80 -p 443:443";
fi
sudo docker run -i -t -d --restart=always --name ${DOCUMENT_CONTAINER_NAME} ${DOCUMENT_SERVER_ADDITIONAL_PORTS} \
-v /app/onlyoffice/DocumentServer/data:/var/www/onlyoffice/Data \
-v /app/onlyoffice/DocumentServer/logs:/var/log/onlyoffice \
${DOCUMENT_IMAGE_NAME}:${DOCUMENT_VERSION}
@ -742,6 +774,8 @@ install_document_server () {
install_mail_server () {
MAIL_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${MAIL_CONTAINER_NAME});
MAIL_SERVER_ADDITIONAL_PORTS="";
if [[ -n ${MAIL_SERVER_ID} ]]; then
if [ "$UPDATE" == "true" ]; then
check_bindings $MAIL_SERVER_ID;
@ -756,28 +790,31 @@ install_mail_server () {
if [[ -z ${MAIL_VERSION} ]]; then
MAIL_VERSION=$(get_available_version "$MAIL_IMAGE_NAME");
fi
if [ "${USE_AS_EXTERNAL_SERVER}" == "true" ]; then
MAIL_SERVER_ADDITIONAL_PORTS="-p 3306:3306 -p 8081:8081";
fi
RUN_COMMAND="sudo docker run --privileged -i -t -d --restart=always --name ${MAIL_CONTAINER_NAME} ${MAIL_SERVER_ADDITIONAL_PORTS} -p 25:25 -p 143:143 -p 587:587";
RUN_COMMAND="${RUN_COMMAND} -v /app/onlyoffice/MailServer/data:/var/vmail";
RUN_COMMAND="${RUN_COMMAND} -v /app/onlyoffice/MailServer/data/certs:/etc/pki/tls/mailserver";
RUN_COMMAND="${RUN_COMMAND} -v /app/onlyoffice/MailServer/logs:/var/log";
RUN_COMMAND="${RUN_COMMAND} -v /app/onlyoffice/MailServer/mysql:/var/lib/mysql";
if [ "$UPDATE" != "true" ]; then
if [[ -z ${MAIL_DOMAIN_NAME} ]]; then
echo "Please, set domain name for mail server"
exit 0;
fi
sudo docker run --privileged -i -t -d --restart=always --name ${MAIL_CONTAINER_NAME} -p 25:25 -p 143:143 -p 587:587 \
-v /app/onlyoffice/MailServer/data:/var/vmail \
-v /app/onlyoffice/MailServer/data/certs:/etc/pki/tls/mailserver \
-v /app/onlyoffice/MailServer/logs:/var/log -v \
/app/onlyoffice/MailServer/mysql:/var/lib/mysql -h ${MAIL_DOMAIN_NAME} ${MAIL_IMAGE_NAME}:${MAIL_VERSION}
RUN_COMMAND="${RUN_COMMAND} -h ${MAIL_DOMAIN_NAME} ${MAIL_IMAGE_NAME}:${MAIL_VERSION}";
else
sudo docker run --privileged -i -t -d --restart=always --name ${MAIL_CONTAINER_NAME} -p 25:25 -p 143:143 -p 587:587 \
-v /app/onlyoffice/MailServer/data:/var/vmail \
-v /app/onlyoffice/MailServer/data/certs:/etc/pki/tls/mailserver \
-v /app/onlyoffice/MailServer/logs:/var/log -v \
/app/onlyoffice/MailServer/mysql:/var/lib/mysql ${MAIL_IMAGE_NAME}:${MAIL_VERSION}
RUN_COMMAND="${RUN_COMMAND} ${MAIL_IMAGE_NAME}:${MAIL_VERSION}";
fi
${RUN_COMMAND};
MAIL_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${MAIL_CONTAINER_NAME});
if [[ -z ${MAIL_SERVER_ID} ]]; then
@ -789,6 +826,8 @@ install_mail_server () {
install_controlpanel () {
CONTROL_PANEL_ID=$(sudo docker inspect --format='{{.Id}}' ${CONTROLPANEL_CONTAINER_NAME});
CONTROLPANEL_ADDITIONS_PARAMS="";
if [[ -n ${CONTROL_PANEL_ID} ]]; then
if [ "$UPDATE" == "true" ]; then
check_bindings $CONTROL_PANEL_ID;
@ -804,7 +843,19 @@ install_controlpanel () {
CONTROLPANEL_VERSION=$(get_available_version "$CONTROLPANEL_IMAGE_NAME");
fi
sudo docker run -i -t -d --restart=always --name ${CONTROLPANEL_CONTAINER_NAME} \
if [[ -n ${MAIL_SERVER_HOST} ]]; then
CONTROLPANEL_ADDITIONS_PARAMS="${CONTROLPANEL_ADDITIONS_PARAMS} -e MAIL_SERVER_EXTERNAL=true";
fi
if [[ -n ${DOCUMENT_SERVER_HOST} ]]; then
CONTROLPANEL_ADDITIONS_PARAMS="${CONTROLPANEL_ADDITIONS_PARAMS} -e DOCUMENT_SERVER_EXTERNAL=true";
fi
if [[ -n ${COMMUNITY_SERVER_HOST} ]]; then
CONTROLPANEL_ADDITIONS_PARAMS="${CONTROLPANEL_ADDITIONS_PARAMS} -e COMMUNITY_SERVER_EXTERNAL=true";
fi
sudo docker run -i -t -d --restart=always --name ${CONTROLPANEL_CONTAINER_NAME} ${CONTROLPANEL_ADDITIONS_PARAMS} \
-v /var/run/docker.sock:/var/run/docker.sock \
-v /app/onlyoffice/CommunityServer/data:/app/onlyoffice/CommunityServer/data \
-v /app/onlyoffice/DocumentServer/data:/app/onlyoffice/DocumentServer/data \
@ -847,6 +898,14 @@ install_community_server () {
RUN_COMMAND="sudo docker run --name $COMMUNITY_CONTAINER_NAME -i -t -d --restart=always -p $COMMUNITY_PORT:80 -p 443:443 -p 5222:5222";
if [[ -n ${MAIL_SERVER_HOST} ]]; then
RUN_COMMAND="$RUN_COMMAND -e MAIL_SERVER_DB_HOST='${MAIL_SERVER_HOST}'";
fi
if [[ -n ${DOCUMENT_SERVER_HOST} ]]; then
RUN_COMMAND="$RUN_COMMAND -e DOCUMENT_SERVER_HOST='${DOCUMENT_SERVER_HOST}'";
fi
if [[ -n ${DOCUMENT_SERVER_ID} ]]; then
RUN_COMMAND="$RUN_COMMAND --link $DOCUMENT_CONTAINER_NAME:document_server";
fi
@ -922,7 +981,9 @@ start_installation () {
check_kernel
check_ports
if [ "$UPDATE" != "true" ]; then
check_ports
fi
if ! command_exists docker ; then
install_docker;

199
web/Executables/restart.sh Normal file
View File

@ -0,0 +1,199 @@
#/bin/bash
# (c) Copyright Ascensio System Limited 2010-2015
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
COMMUNITY_CONTAINER_NAME="onlyoffice-community-server";
DOCUMENT_CONTAINER_NAME="onlyoffice-document-server";
MAIL_CONTAINER_NAME="onlyoffice-mail-server";
CONTROLPANEL_CONTAINER_NAME="onlyoffice-control-panel";
FAST="false"
while [ "$1" != "" ]; do
case $1 in
-cc | --communitycontainer )
if [ "$2" != "" ]; then
COMMUNITY_CONTAINER_NAME=$2
shift
fi
;;
-dc | --documentcontainer )
if [ "$2" != "" ]; then
DOCUMENT_CONTAINER_NAME=$2
shift
fi
;;
-mc | --mailcontainer )
if [ "$2" != "" ]; then
MAIL_CONTAINER_NAME=$2
shift
fi
;;
-cpc | --controlpanelcontainer )
if [ "$2" != "" ]; then
CONTROLPANEL_CONTAINER_NAME=$2
shift
fi
;;
-f | --fast )
if [ "$2" != "" ]; then
FAST=$2
shift
fi
;;
-? | -h | --help )
echo " Usage $0 [PARAMETER] [[PARAMETER], ...]"
echo " Parameters:"
echo " -cc, --communitycontainer community container name"
echo " -dc, --documentcontainer document container name"
echo " -mc, --mailcontainer mail container name"
echo " -cpc, --controlpanelcontainer control panel container name"
echo " -f, --fast fast restart services in community container"
echo " -?, -h, --help this help"
echo
exit 0
;;
* )
echo "Unknown parameter $1" 1>&2
exit 0
;;
esac
shift
done
root_checking () {
if [ ! $( id -u ) -eq 0 ]; then
echo "To perform this action you must be logged in with root rights"
exit 0;
fi
}
command_exists () {
type "$1" &> /dev/null;
}
install_sudo () {
if command_exists apt-get; then
apt-get install sudo
elif command_exists yum; then
yum install sudo
fi
if ! command_exists sudo; then
echo "command sudo not found"
exit 0;
fi
}
fast_restart () {
COMMUNITY_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${COMMUNITY_CONTAINER_NAME});
if [[ -n ${COMMUNITY_SERVER_ID} ]]; then
sudo docker exec ${COMMUNITY_CONTAINER_NAME} service monoserve restart;
sudo docker exec ${COMMUNITY_CONTAINER_NAME} service monoserve2 restart;
sudo docker exec ${COMMUNITY_CONTAINER_NAME} service nginx restart;
else
echo "COMMUNITY SERVER not found"
fi
}
restart_document_server () {
DOCUMENT_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${DOCUMENT_CONTAINER_NAME});
if [[ -n ${DOCUMENT_SERVER_ID} ]]; then
if [[ -z "$1" ]]; then
sudo docker restart ${DOCUMENT_SERVER_ID};
else
sudo docker $1 ${DOCUMENT_SERVER_ID};
fi
else
echo "DOCUMENT SERVER not found"
fi
}
restart_mail_server () {
MAIL_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${MAIL_CONTAINER_NAME});
if [[ -n ${MAIL_SERVER_ID} ]]; then
if [[ -z "$1" ]]; then
sudo docker restart ${MAIL_SERVER_ID};
else
sudo docker $1 ${MAIL_SERVER_ID};
fi
else
echo "MAIL SERVER not found"
fi
}
restart_controlpanel () {
CONTROL_PANEL_ID=$(sudo docker inspect --format='{{.Id}}' ${CONTROLPANEL_CONTAINER_NAME});
if [[ -n ${CONTROL_PANEL_ID} ]]; then
if [[ -z "$1" ]]; then
sudo docker restart ${CONTROL_PANEL_ID};
else
sudo docker $1 ${CONTROL_PANEL_ID};
fi
else
echo "CONTROL PANEL not found"
fi
}
restart_community_server () {
COMMUNITY_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${COMMUNITY_CONTAINER_NAME});
if [[ -n ${COMMUNITY_SERVER_ID} ]]; then
if [[ -z "$1" ]]; then
sudo docker restart ${COMMUNITY_SERVER_ID};
else
sudo docker $1 ${COMMUNITY_SERVER_ID};
fi
else
echo "COMMUNITY SERVER not found"
fi
}
start_restart () {
root_checking
if ! command_exists sudo ; then
install_sudo;
fi
if [ "$FAST" == "true" ]; then
fast_restart
else
restart_document_server "stop"
restart_mail_server "stop"
restart_controlpanel "stop"
restart_community_server "stop"
restart_document_server "start"
restart_mail_server "start"
restart_controlpanel "start"
restart_community_server "start"
fi
echo "restart complete"
exit 0;
}
start_restart

View File

@ -11,31 +11,169 @@
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
MAIL_SERVER_ID=$(sudo docker ps -a | grep 'onlyoffice-mail-server' | awk '{print $1}');
DOCUMENT_SERVER_ID=$(sudo docker ps -a | grep 'onlyoffice-document-server' | awk '{print $1}');
COMMUNITY_SERVER_ID=$(sudo docker ps -a | grep 'onlyoffice-community-server' | awk '{print $1}');
UPDATE=0
COMMUNITY_PORT=80
COMMUNITY_IMAGE_NAME='onlyoffice/communityserver';
COMMUNITY_CONTAINER_NAME='onlyoffice-community-server';
DOCUMENT_CONTAINER_NAME='onlyoffice-document-server';
MAIL_CONTAINER_NAME='onlyoffice-mail-server';
CONTROLPANEL_CONTAINER_NAME='onlyoffice-control-panel';
while [ "$1" != "" ]; do
case $1 in
-u | --update )
UPDATE=1
;;
-i | --image )
if [ "$2" != "" ]; then
COMMUNITY_IMAGE_NAME=$2
shift
fi
;;
-v | --version )
if [ "$2" != "" ]; then
VERSION=$2
shift
fi
;;
-c | --container )
if [ "$2" != "" ]; then
COMMUNITY_CONTAINER_NAME=$2
shift
fi
;;
-dc | --documentcontainer )
if [ "$2" != "" ]; then
DOCUMENT_CONTAINER_NAME=$2
shift
fi
;;
-mc | --mailcontainer )
if [ "$2" != "" ]; then
MAIL_CONTAINER_NAME=$2
shift
fi
;;
-cc | --controlpanelcontainer )
if [ "$2" != "" ]; then
CONTROLPANEL_CONTAINER_NAME=$2
shift
fi
;;
-p | --password )
if [ "$2" != "" ]; then
PASSWORD=$2
shift
fi
;;
-un | --username )
if [ "$2" != "" ]; then
USERNAME=$2
shift
fi
;;
-? | -h | --help )
echo " Usage $0 [PARAMETER] [[PARAMETER], ...]"
echo " Parameters:"
echo " -u, --update update"
echo " -i, --image image name"
echo " -v, --version image version"
echo " -c, --container container name"
echo " -dc, --documentcontainer document container name"
echo " -mc, --mailcontainer mail container name"
echo " -cc, --controlpanelcontainer controlpanel container name"
echo " -p, --password dockerhub password"
echo " -un, --username dockerhub username"
echo " -?, -h, --help this help"
echo
exit 0
;;
* )
echo "Unknown parameter $1" 1>&2
exit 1
;;
esac
shift
done
COMMUNITY_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${COMMUNITY_CONTAINER_NAME});
DOCUMENT_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${DOCUMENT_CONTAINER_NAME});
MAIL_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${MAIL_CONTAINER_NAME});
CONTROL_PANEL_ID=$(sudo docker inspect --format='{{.Id}}' ${CONTROLPANEL_CONTAINER_NAME});
if [[ -n ${COMMUNITY_SERVER_ID} ]]; then
echo "ONLYOFFICE COMMUNITY SERVER is already installed."
if [ "$UPDATE" == "1" ]; then
sudo bash /app/onlyoffice/setup/tools/check-bindings.sh ${COMMUNITY_SERVER_ID}
sudo docker start ${COMMUNITY_SERVER_ID};
COMMUNITY_PORT=$(sudo docker port $COMMUNITY_SERVER_ID 80 | sed 's/.*://')
echo "INSTALLATION-STOP-SUCCESS"
exit 0;
sudo bash /app/onlyoffice/setup/tools/remove-container.sh ${COMMUNITY_CONTAINER_NAME}
else
echo "ONLYOFFICE COMMUNITY SERVER is already installed."
sudo docker start ${COMMUNITY_SERVER_ID};
echo "INSTALLATION-STOP-SUCCESS"
exit 0;
fi
fi
RUN_COMMAND="sudo docker run --restart=always --name onlyoffice-community-server -i -t -d -p 80:80 -p 443:443 -p 5222:5222";
if [[ -n ${USERNAME} && -n ${PASSWORD} ]]; then
sudo bash /app/onlyoffice/setup/tools/login-docker.sh ${USERNAME} ${PASSWORD}
fi
if [[ -z ${VERSION} ]]; then
GET_VERSION_COMMAND="sudo bash /app/onlyoffice/setup/tools/get-available-version.sh -i $COMMUNITY_IMAGE_NAME";
if [[ -n ${PASSWORD} && -n ${USERNAME} ]]; then
GET_VERSION_COMMAND="$GET_VERSION_COMMAND -un $USERNAME -p $PASSWORD";
fi
VERSION=$(${GET_VERSION_COMMAND});
fi
RUN_COMMAND="sudo docker run --net onlyoffice --name $COMMUNITY_CONTAINER_NAME -i -t -d --restart=always -p $COMMUNITY_PORT:80 -p 443:443 -p 5222:5222";
RUN_COMMAND="$RUN_COMMAND -e ONLYOFFICE_MONOSERVE_COUNT=2";
if [[ -n ${DOCUMENT_SERVER_ID} ]]; then
RUN_COMMAND="$RUN_COMMAND --link onlyoffice-document-server:document_server";
RUN_COMMAND="$RUN_COMMAND -e DOCUMENT_SERVER_PORT_80_TCP_ADDR=$DOCUMENT_CONTAINER_NAME";
fi
if [[ -n ${MAIL_SERVER_ID} ]]; then
RUN_COMMAND="$RUN_COMMAND --link onlyoffice-mail-server:mail_server";
fi
RUN_COMMAND="$RUN_COMMAND -e MAIL_SERVER_DB_HOST=${MAIL_CONTAINER_NAME}";
fi
RUN_COMMAND="$RUN_COMMAND -v /app/onlyoffice/CommunityServer/data:/var/www/onlyoffice/Data -v /app/onlyoffice/CommunityServer/mysql:/var/lib/mysql -v /app/onlyoffice/CommunityServer/logs:/var/log/onlyoffice onlyoffice/communityserver";
if [[ -n ${CONTROL_PANEL_ID} ]]; then
RUN_COMMAND="$RUN_COMMAND -e CONTROL_PANEL_PORT_80_TCP=80";
RUN_COMMAND="$RUN_COMMAND -e CONTROL_PANEL_PORT_80_TCP_ADDR=$CONTROLPANEL_CONTAINER_NAME";
fi
RUN_COMMAND="$RUN_COMMAND -v /app/onlyoffice/CommunityServer/data:/var/www/onlyoffice/Data";
RUN_COMMAND="$RUN_COMMAND -v /app/onlyoffice/CommunityServer/mysql:/var/lib/mysql";
RUN_COMMAND="$RUN_COMMAND -v /app/onlyoffice/CommunityServer/logs:/var/log/onlyoffice";
RUN_COMMAND="$RUN_COMMAND -v /app/onlyoffice/DocumentServer/data:/var/www/onlyoffice/DocumentServerData";
RUN_COMMAND="$RUN_COMMAND $COMMUNITY_IMAGE_NAME:$VERSION";
${RUN_COMMAND};
echo "INSTALLATION-STOP-SUCCESS"
COMMUNITY_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${COMMUNITY_CONTAINER_NAME});
if [[ -z ${COMMUNITY_SERVER_ID} ]]; then
echo "ONLYOFFICE COMMUNITY SERVER not installed."
echo "INSTALLATION-STOP-ERROR"
exit 0;
fi
echo "ONLYOFFICE COMMUNITY SERVER successfully installed."
echo "INSTALLATION-STOP-SUCCESS"

View File

@ -0,0 +1,133 @@
#/bin/bash
# (c) Copyright Ascensio System Limited 2010-2015
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
UPDATE=0
CONTROLPANEL_IMAGE_NAME='onlyoffice/controlpanel';
CONTROLPANEL_CONTAINER_NAME='onlyoffice-control-panel';
while [ "$1" != "" ]; do
case $1 in
-u | --update )
UPDATE=1
;;
-i | --image )
if [ "$2" != "" ]; then
CONTROLPANEL_IMAGE_NAME=$2
shift
fi
;;
-v | --version )
if [ "$2" != "" ]; then
VERSION=$2
shift
fi
;;
-c | --container )
if [ "$2" != "" ]; then
CONTROLPANEL_CONTAINER_NAME=$2
shift
fi
;;
-p | --password )
if [ "$2" != "" ]; then
PASSWORD=$2
shift
fi
;;
-un | --username )
if [ "$2" != "" ]; then
USERNAME=$2
shift
fi
;;
-? | -h | --help )
echo " Usage $0 [PARAMETER] [[PARAMETER], ...]"
echo " Parameters:"
echo " -u, --update update"
echo " -i, --image image name"
echo " -v, --version image version"
echo " -c, --container container name"
echo " -p, --password dockerhub password"
echo " -un, --username dockerhub username"
echo " -?, -h, --help this help"
echo
exit 0
;;
* )
echo "Unknown parameter $1" 1>&2
exit 1
;;
esac
shift
done
CONTROL_PANEL_ID=$(sudo docker inspect --format='{{.Id}}' ${CONTROLPANEL_CONTAINER_NAME});
if [[ -n ${CONTROL_PANEL_ID} ]]; then
if [ "$UPDATE" == "1" ]; then
sudo bash /app/onlyoffice/setup/tools/check-bindings.sh ${CONTROL_PANEL_ID}
sudo bash /app/onlyoffice/setup/tools/remove-container.sh ${CONTROLPANEL_CONTAINER_NAME}
else
echo "ONLYOFFICE CONTROL PANEL is already installed."
sudo docker start ${CONTROL_PANEL_ID};
echo "INSTALLATION-STOP-SUCCESS"
exit 0;
fi
fi
if [[ -n ${USERNAME} && -n ${PASSWORD} ]]; then
sudo bash /app/onlyoffice/setup/tools/login-docker.sh ${USERNAME} ${PASSWORD}
fi
if [[ -z ${VERSION} ]]; then
GET_VERSION_COMMAND="sudo bash /app/onlyoffice/setup/tools/get-available-version.sh -i $CONTROLPANEL_IMAGE_NAME";
if [[ -n ${PASSWORD} && -n ${USERNAME} ]]; then
GET_VERSION_COMMAND="$GET_VERSION_COMMAND -un $USERNAME -p $PASSWORD";
fi
VERSION=$(${GET_VERSION_COMMAND});
fi
sudo bash /app/onlyoffice/setup/tools/pull-image.sh ${CONTROLPANEL_IMAGE_NAME} ${VERSION}
sudo docker run --net onlyoffice -i -t -d --restart=always --name ${CONTROLPANEL_CONTAINER_NAME} \
-v /var/run/docker.sock:/var/run/docker.sock \
-v /app/onlyoffice/CommunityServer/data:/app/onlyoffice/CommunityServer/data \
-v /app/onlyoffice/DocumentServer/data:/app/onlyoffice/DocumentServer/data \
-v /app/onlyoffice/MailServer/data:/app/onlyoffice/MailServer/data \
-v /app/onlyoffice/ControlPanel/data:/var/www/onlyoffice-controlpanel/Data \
-v /app/onlyoffice/ControlPanel/logs:/var/log/onlyoffice-controlpanel \
-v /app/onlyoffice/ControlPanel/mysql:/var/lib/mysql \
${CONTROLPANEL_IMAGE_NAME}:${VERSION}
CONTROL_PANEL_ID=$(sudo docker inspect --format='{{.Id}}' ${CONTROLPANEL_CONTAINER_NAME});
if [[ -z ${CONTROL_PANEL_ID} ]]; then
echo "ONLYOFFICE CONTROL PANEL not installed."
echo "INSTALLATION-STOP-ERROR"
exit 0;
fi
echo "ONLYOFFICE CONTROL PANEL successfully installed."
echo "INSTALLATION-STOP-SUCCESS"

View File

@ -11,20 +11,118 @@
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
DOCUMENT_SERVER_ID=$(sudo docker ps -a | grep 'onlyoffice-document-server' | awk '{print $1}');
UPDATE=0
DOCUMENT_IMAGE_NAME='onlyoffice/documentserver';
DOCUMENT_CONTAINER_NAME='onlyoffice-document-server';
while [ "$1" != "" ]; do
case $1 in
-u | --update )
UPDATE=1
;;
-i | --image )
if [ "$2" != "" ]; then
DOCUMENT_IMAGE_NAME=$2
shift
fi
;;
-v | --version )
if [ "$2" != "" ]; then
VERSION=$2
shift
fi
;;
-c | --container )
if [ "$2" != "" ]; then
DOCUMENT_CONTAINER_NAME=$2
shift
fi
;;
-p | --password )
if [ "$2" != "" ]; then
PASSWORD=$2
shift
fi
;;
-un | --username )
if [ "$2" != "" ]; then
USERNAME=$2
shift
fi
;;
-? | -h | --help )
echo " Usage $0 [PARAMETER] [[PARAMETER], ...]"
echo " Parameters:"
echo " -u, --update update"
echo " -i, --image image name"
echo " -v, --version image version"
echo " -c, --container container name"
echo " -p, --password dockerhub password"
echo " -un, --username dockerhub username"
echo " -?, -h, --help this help"
echo
exit 0
;;
* )
echo "Unknown parameter $1" 1>&2
exit 1
;;
esac
shift
done
DOCUMENT_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${DOCUMENT_CONTAINER_NAME});
if [[ -n ${DOCUMENT_SERVER_ID} ]]; then
echo "ONLYOFFICE DOCUMENT SERVER is already installed."
sudo docker start ${DOCUMENT_SERVER_ID};
echo "INSTALLATION-STOP-SUCCESS"
exit 0;
if [ "$UPDATE" == "1" ]; then
sudo bash /app/onlyoffice/setup/tools/check-bindings.sh ${DOCUMENT_SERVER_ID} "/etc/onlyoffice,/var/lib/onlyoffice"
sudo bash /app/onlyoffice/setup/tools/remove-container.sh ${DOCUMENT_CONTAINER_NAME}
else
echo "ONLYOFFICE DOCUMENT SERVER is already installed."
sudo docker start ${DOCUMENT_SERVER_ID};
echo "INSTALLATION-STOP-SUCCESS"
exit 0;
fi
fi
sudo docker run --restart=always -i -t -d --name onlyoffice-document-server \
if [[ -n ${USERNAME} && -n ${PASSWORD} ]]; then
sudo bash /app/onlyoffice/setup/tools/login-docker.sh ${USERNAME} ${PASSWORD}
fi
if [[ -z ${VERSION} ]]; then
GET_VERSION_COMMAND="sudo bash /app/onlyoffice/setup/tools/get-available-version.sh -i $DOCUMENT_IMAGE_NAME";
if [[ -n ${PASSWORD} && -n ${USERNAME} ]]; then
GET_VERSION_COMMAND="$GET_VERSION_COMMAND -un $USERNAME -p $PASSWORD";
fi
VERSION=$(${GET_VERSION_COMMAND});
fi
sudo bash /app/onlyoffice/setup/tools/pull-image.sh ${DOCUMENT_IMAGE_NAME} ${VERSION}
sudo docker run --net onlyoffice -i -t -d --restart=always --name ${DOCUMENT_CONTAINER_NAME} \
-v /app/onlyoffice/DocumentServer/data:/var/www/onlyoffice/Data \
-v /app/onlyoffice/DocumentServer/logs:/var/log/onlyoffice \
onlyoffice/documentserver
${DOCUMENT_IMAGE_NAME}:${VERSION}
echo "INSTALLATION-STOP-SUCCESS"
DOCUMENT_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${DOCUMENT_CONTAINER_NAME});
if [[ -z ${DOCUMENT_SERVER_ID} ]]; then
echo "ONLYOFFICE DOCUMENT SERVER not installed."
echo "INSTALLATION-STOP-ERROR"
exit 0;
fi
echo "ONLYOFFICE DOCUMENT SERVER successfully installed."
echo "INSTALLATION-STOP-SUCCESS"

View File

@ -11,30 +11,139 @@
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
MAIL_SERVER_ID=$(sudo docker ps -a | grep 'onlyoffice-mail-server' | awk '{print $1}');
UPDATE=0
MAIL_IMAGE_NAME='onlyoffice/mailserver';
MAIL_CONTAINER_NAME='onlyoffice-mail-server';
while [ "$1" != "" ]; do
case $1 in
-u | --update )
UPDATE=1
;;
-i | --image )
if [ "$2" != "" ]; then
MAIL_IMAGE_NAME=$2
shift
fi
;;
-v | --version )
if [ "$2" != "" ]; then
VERSION=$2
shift
fi
;;
-c | --container )
if [ "$2" != "" ]; then
MAIL_CONTAINER_NAME=$2
shift
fi
;;
-d | --domain )
if [ "$2" != "" ]; then
MAIL_DOMAIN_NAME=$2
shift
fi
;;
-p | --password )
if [ "$2" != "" ]; then
PASSWORD=$2
shift
fi
;;
-un | --username )
if [ "$2" != "" ]; then
USERNAME=$2
shift
fi
;;
-? | -h | --help )
echo " Usage $0 [PARAMETER] [[PARAMETER], ...]"
echo " Parameters:"
echo " -u, --update update"
echo " -i, --image image name"
echo " -v, --version image version"
echo " -c, --container container name"
echo " -d, --domain domain name"
echo " -p, --password dockerhub password"
echo " -un, --username dockerhub username"
echo " -?, -h, --help this help"
echo
exit 0
;;
* )
echo "Unknown parameter $1" 1>&2
exit 1
;;
esac
shift
done
MAIL_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${MAIL_CONTAINER_NAME});
if [[ -n ${MAIL_SERVER_ID} ]]; then
echo "ONLYOFFICE MAIL SERVER is already installed."
if [ "$UPDATE" == "1" ]; then
sudo bash /app/onlyoffice/setup/tools/check-bindings.sh ${MAIL_SERVER_ID}
sudo docker start ${MAIL_SERVER_ID};
if [[ -z ${MAIL_DOMAIN_NAME} ]]; then
MAIL_DOMAIN_NAME=$(sudo docker exec $MAIL_SERVER_ID hostname -f);
fi
echo "INSTALLATION-STOP-SUCCESS"
exit 0;
sudo bash /app/onlyoffice/setup/tools/remove-container.sh ${MAIL_CONTAINER_NAME}
else
echo "ONLYOFFICE MAIL SERVER is already installed."
sudo docker start ${MAIL_SERVER_ID};
echo "INSTALLATION-STOP-SUCCESS"
exit 0;
fi
fi
MAIL_SERVER_HOSTNAME=${1};
if [[ -n ${USERNAME} && -n ${PASSWORD} ]]; then
sudo bash /app/onlyoffice/setup/tools/login-docker.sh ${USERNAME} ${PASSWORD}
fi
if [[ -z ${MAIL_SERVER_HOSTNAME} ]]; then
echo "Please, set hostname for mail server"
if [[ -z ${VERSION} ]]; then
GET_VERSION_COMMAND="sudo bash /app/onlyoffice/setup/tools/get-available-version.sh -i $MAIL_IMAGE_NAME";
if [[ -n ${PASSWORD} && -n ${USERNAME} ]]; then
GET_VERSION_COMMAND="$GET_VERSION_COMMAND -un $USERNAME -p $PASSWORD";
fi
VERSION=$(${GET_VERSION_COMMAND});
fi
if [[ -z ${MAIL_DOMAIN_NAME} ]]; then
echo "Please, set domain name for mail server"
echo "INSTALLATION-STOP-ERROR[4]"
exit 0;
fi
sudo docker run --restart=always --privileged -i -t -d --name onlyoffice-mail-server -p 25:25 -p 143:143 -p 587:587 \
sudo bash /app/onlyoffice/setup/tools/pull-image.sh ${MAIL_IMAGE_NAME} ${VERSION}
sudo docker run --net onlyoffice --privileged -i -t -d --restart=always --name ${MAIL_CONTAINER_NAME} -p 25:25 -p 143:143 -p 587:587 \
-v /app/onlyoffice/MailServer/data:/var/vmail \
-v /app/onlyoffice/MailServer/data/certs:/etc/pki/tls/mailserver \
-v /app/onlyoffice/MailServer/logs:/var/log -v \
/app/onlyoffice/MailServer/mysql:/var/lib/mysql -h ${MAIL_SERVER_HOSTNAME} onlyoffice/mailserver
-v /app/onlyoffice/MailServer/logs:/var/log \
-v /app/onlyoffice/MailServer/mysql:/var/lib/mysql \
-h ${MAIL_DOMAIN_NAME} ${MAIL_IMAGE_NAME}:${VERSION}
echo "INSTALLATION-STOP-SUCCESS"
MAIL_SERVER_ID=$(sudo docker inspect --format='{{.Id}}' ${MAIL_CONTAINER_NAME});
if [[ -z ${MAIL_SERVER_ID} ]]; then
echo "ONLYOFFICE MAIL SERVER not installed."
echo "INSTALLATION-STOP-ERROR"
exit 0;
fi
echo "ONLYOFFICE MAIL SERVER successfully installed."
echo "INSTALLATION-STOP-SUCCESS"

View File

@ -0,0 +1,52 @@
#!/bin/bash
# (c) Copyright Ascensio System Limited 2010-2015
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
if [[ -z "$1" ]]; then
echo "container id is empty";
exit 0;
fi
binds=$(sudo docker inspect --format='{{range $p,$conf:=.HostConfig.Binds}}{{$conf}};{{end}}' $1)
volumes=$(sudo docker inspect --format='{{range $p,$conf:=.Config.Volumes}}{{$p}};{{end}}' $1)
arrBinds=$(echo $binds | tr ";" "\n")
arrVolumes=$(echo $volumes | tr ";" "\n")
bindsCorrect=1
if [[ -n "$2" ]]; then
exceptions=$(echo $2 | tr "," "\n")
for ex in ${exceptions[@]}
do
arrVolumes=(${arrVolumes[@]/$ex})
done
fi
for volume in $arrVolumes
do
bindExist=0
for bind in $arrBinds
do
bind=($(echo $bind | tr ":" " "))
if [ "${bind[1]}" == "${volume}" ]; then
bindExist=1
fi
done
if [ "$bindExist" = "0" ]; then
bindsCorrect=0
echo "${volume} not binded"
fi
done
if [ "$bindsCorrect" = "0" ]; then
echo "INSTALLATION-STOP-ERROR";
exit 0;
fi

View File

@ -11,31 +11,19 @@
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
CHECK_25=${1:-false}
STR_PORTS=${1}
ARRAY_PORTS=(${STR_PORTS//,/ })
if [ "`sudo netstat -lnp | grep ':80'`" != "" ]; then
echo "The following ports must be open: 80"
echo "INSTALLATION-STOP-ERROR[3]"
exit 0;
fi
for PORT in "${ARRAY_PORTS[@]}"
do
REGEXP=":$PORT$"
CHECK_RESULT=$(sudo netstat -lnp | awk '{print $4}' | grep $REGEXP)
if [ "`sudo netstat -lnp | grep ':443'`" != "" ]; then
echo "The following ports must be open: 443"
echo "INSTALLATION-STOP-ERROR[3]"
exit 0;
fi
if [ "${CHECK_25}" == "true" ] ; then
if [ "`sudo netstat -lnp | grep ':25'`" != "" ]; then
echo "The following ports must be open: 25"
if [[ $CHECK_RESULT != "" ]]; then
echo "The following ports must be open: $PORT"
echo "INSTALLATION-STOP-ERROR[3]"
exit 0;
fi
done
fi
echo "INSTALLATION-STOP-SUCCESS"
echo "INSTALLATION-STOP-SUCCESS"

View File

@ -11,16 +11,80 @@
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
MAIL_SERVER_ID="";
DOCUMENT_SERVER_ID="";
COMMUNITY_SERVER_ID="";
COMMUNITY_SERVER_VERSION='';
DOCUMENT_SERVER_VERSION='';
MAIL_SERVER_VERSION='';
CONTROL_PANEL_VERSION='';
LICENSE_FILE_EXIST="false";
COMMUNITY_CONTAINER_NAME='onlyoffice-community-server';
DOCUMENT_CONTAINER_NAME='onlyoffice-document-server';
MAIL_CONTAINER_NAME='onlyoffice-mail-server';
CONTROLPANEL_CONTAINER_NAME='onlyoffice-control-panel';
while [ "$1" != "" ]; do
case $1 in
-cc | --communitycontainer )
if [ "$2" != "" ]; then
COMMUNITY_CONTAINER_NAME=$2
shift
fi
;;
-dc | --documentcontainer )
if [ "$2" != "" ]; then
DOCUMENT_CONTAINER_NAME=$2
shift
fi
;;
-mc | --mailcontainer )
if [ "$2" != "" ]; then
MAIL_CONTAINER_NAME=$2
shift
fi
;;
-cpc | --controlpanelcontainer )
if [ "$2" != "" ]; then
CONTROLPANEL_CONTAINER_NAME=$2
shift
fi
;;
-? | -h | --help )
echo " Usage $0 [PARAMETER] [[PARAMETER], ...]"
echo " Parameters:"
echo " -cc, --communitycontainer community container name"
echo " -dc, --documentcontainer document container name"
echo " -mc, --mailcontainer mail container name"
echo " -cpc, --controlpanelcontainer controlpanel container name"
echo " -?, -h, --help this help"
echo
exit 0
;;
* )
echo "Unknown parameter $1" 1>&2
exit 1
;;
esac
shift
done
root_checking () {
if [ ! $( id -u ) -eq 0 ]; then
echo "To perform this action you must be logged in with root rights"
echo "INSTALLATION-STOP-ERROR[8]"
exit 0;
fi
}
command_exists () {
type "$1" &> /dev/null ;
}
install_sudo () {
if command_exists apt-get ; then
apt-get install sudo
@ -37,6 +101,28 @@ install_sudo () {
fi
}
check_license_file_in_dir () {
if [ "LICENSE_FILE_EXIST" != "true" ]; then
if [ -d "$1" ]; then
for file in "$1"/*.lic
do
if [ -f "${file}" ]; then
LICENSE_FILE_EXIST="true";
break
fi
done
fi
fi
}
check_license_file () {
check_license_file_in_dir "/app/onlyoffice/DocumentServer/data"
check_license_file_in_dir "/app/onlyoffice/DocumentServer/data"
check_license_file_in_dir "/app/onlyoffice/MailServer/data"
check_license_file_in_dir "/app/onlyoffice/ControlPanel/data"
}
root_checking
if ! command_exists sudo ; then
install_sudo;
@ -44,15 +130,19 @@ fi
if command_exists docker ; then
MAIL_SERVER_ID=$(sudo docker ps -a | grep 'onlyoffice-mail-server' | awk '{print $1}');
DOCUMENT_SERVER_ID=$(sudo docker ps -a | grep 'onlyoffice-document-server' | awk '{print $1}');
COMMUNITY_SERVER_ID=$(sudo docker ps -a | grep 'onlyoffice-community-server' | awk '{print $1}');
MAIL_SERVER_VERSION=$(sudo docker ps -a | grep ${MAIL_CONTAINER_NAME} | awk '{print $2}' | sed 's/.*://');
DOCUMENT_SERVER_VERSION=$(sudo docker ps -a | grep ${DOCUMENT_CONTAINER_NAME} | awk '{print $2}' | sed 's/.*://');
COMMUNITY_SERVER_VERSION=$(sudo docker ps -a | grep ${COMMUNITY_CONTAINER_NAME} | awk '{print $2}' | sed 's/.*://');
CONTROL_PANEL_VERSION=$(sudo docker ps -a | grep ${CONTROLPANEL_CONTAINER_NAME} | awk '{print $2}' | sed 's/.*://');
fi
check_license_file
echo "MAIL_SERVER_ID: [$MAIL_SERVER_ID]"
echo "DOCUMENT_SERVER_ID: [$DOCUMENT_SERVER_ID]"
echo "COMMUNITY_SERVER_ID: [$COMMUNITY_SERVER_ID]"
echo "MAIL_SERVER_VERSION: [$MAIL_SERVER_VERSION]"
echo "DOCUMENT_SERVER_VERSION: [$DOCUMENT_SERVER_VERSION]"
echo "COMMUNITY_SERVER_VERSION: [$COMMUNITY_SERVER_VERSION]"
echo "CONTROL_PANEL_VERSION: [$CONTROL_PANEL_VERSION]"
echo "LICENSE_FILE_EXIST: [$LICENSE_FILE_EXIST]"
echo "INSTALLATION-STOP-SUCCESS"

View File

@ -0,0 +1,112 @@
#!/bin/bash
# (c) Copyright Ascensio System Limited 2010-2015
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
#!/bin/bash
while [ "$1" != "" ]; do
case $1 in
-i | --image )
IMAGE=$2
shift
;;
-un | --username )
USERNAME=$2
shift
;;
-p | --password )
PASSWORD=$2
shift
;;
-? | -h | --help )
echo " Usage $0 [PARAMETER] [[PARAMETER], ...]"
echo " Parameters:"
echo " -i, --image image"
echo " -un, --username dockerhub username"
echo " -p, --password dockerhub password"
echo " -?, -h, --help this help"
echo
exit 0
;;
* )
echo "Unknown parameter $1" 1>&2
exit 1
;;
esac
shift
done
command_exists () {
type "$1" &> /dev/null;
}
install_curl () {
if command_exists apt-get; then
sudo apt-get -y -q install curl
elif command_exists yum; then
sudo yum -y install curl
fi
if ! command_exists curl; then
echo "command curl not found"
exit 0;
fi
}
if [ "$IMAGE" == "" ]; then
echo "image name is empty"
exit 0
fi
if ! command_exists curl ; then
install_curl;
fi
CREDENTIALS="";
AUTH_HEADER="";
if [[ -n ${USERNAME} && -n ${PASSWORD} ]]; then
CREDENTIALS="{\"username\":\"$USERNAME\",\"password\":\"$PASSWORD\"}";
fi
if [[ -n ${CREDENTIALS} ]]; then
LOGIN_RESP=$(curl -s -H "Content-Type: application/json" -X POST -d "$CREDENTIALS" https://hub.docker.com/v2/users/login/)
TOKEN=$(echo $LOGIN_RESP | sed 's/"token"//g' | tr -d '{}:" ')
AUTH_HEADER="Authorization: JWT $TOKEN"
fi
TAGS_RESP=$(curl -s -H "$AUTH_HEADER" -X GET https://hub.docker.com/v2/repositories/${IMAGE}/tags/);
TAGS_RESP=$(echo $TAGS_RESP | tr -d '[]{},:"')
VERSION_REGEX_1="[0-9]+\.[0-9]+\.[0-9]+"
VERSION_REGEX_2="[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+"
TAG_LIST=""
for item in $TAGS_RESP
do
if [[ $item =~ $VERSION_REGEX_1 ]] || [[ $item =~ $VERSION_REGEX_2 ]]; then
TAG_LIST="$item,$TAG_LIST"
fi
done
LATEST_TAG=$(echo $TAG_LIST | tr ',' '\n' | sort -t. -k 1,1n -k 2,2n -k 3,3n -k 4,4n | awk '/./{line=$0} END{print line}');
echo "$LATEST_TAG"

View File

@ -11,84 +11,72 @@
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
lowercase(){
to_lowercase () {
echo "$1" | sed "y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/"
}
shootProfile(){
OS=`lowercase \`uname\``
KERNEL=`uname -r`
MACH=`uname -m`
get_os_info () {
OS=`to_lowercase \`uname\``
if [ "${OS}" == "windowsnt" ]; then
OS=windows
echo "Not supported OS";
exit 0;
elif [ "${OS}" == "darwin" ]; then
OS=mac
echo "Not supported OS";
exit 0;
else
OS=`uname`
if [ "${OS}" = "SunOS" ] ; then
OS=Solaris
ARCH=`uname -p`
OSSTR="${OS} ${REV}(${ARCH} `uname -v`)"
echo "Not supported OS";
exit 0;
elif [ "${OS}" = "AIX" ] ; then
OSSTR="${OS} `oslevel` (`oslevel -r`)"
echo "Not supported OS";
exit 0;
elif [ "${OS}" = "Linux" ] ; then
MACH=`uname -m`
if [ "${MACH}" != "x86_64" ]; then
echo "Currently only supports 64bit OS's";
exit 0;
fi
KERNEL=`uname -r`
if [ -f /etc/redhat-release ] ; then
DistroBasedOn='RedHat'
DIST=`cat /etc/redhat-release |sed s/\ release.*//`
PSUEDONAME=`cat /etc/redhat-release | sed s/.*\(// | sed s/\)//`
REV=`cat /etc/redhat-release | sed s/.*release\ // | sed s/\ .*//`
elif [ -f /etc/SuSE-release ] ; then
DistroBasedOn='SuSe'
PSUEDONAME=`cat /etc/SuSE-release | tr "\n" ' '| sed s/VERSION.*//`
REV=`cat /etc/SuSE-release | tr "\n" ' ' | sed s/.*=\ //`
elif [ -f /etc/mandrake-release ] ; then
DistroBasedOn='Mandrake'
PSUEDONAME=`cat /etc/mandrake-release | sed s/.*\(// | sed s/\)//`
REV=`cat /etc/mandrake-release | sed s/.*release\ // | sed s/\ .*//`
REV=`cat /etc/os-release | grep '^VERSION_ID' | awk -F= '{ print $2 }' | sed -e 's/^"//' -e 's/"$//'`
DIST='SuSe'
elif [ -f /etc/debian_version ] ; then
DistroBasedOn='Debian'
REV=`cat /etc/debian_version`
DIST=$DistroBasedOn
DIST='Debian'
if [ -f /etc/lsb-release ] ; then
DIST=`cat /etc/lsb-release | grep '^DISTRIB_ID' | awk -F= '{ print $2 }'`
PSUEDONAME=`cat /etc/lsb-release | grep '^DISTRIB_CODENAME' | awk -F= '{ print $2 }'`
REV=`cat /etc/lsb-release | grep '^DISTRIB_RELEASE' | awk -F= '{ print $2 }'`
elif [[ -f /etc/lsb_release ]]; then
DIST=`lsb_release -a 2>&1 | grep 'Distributor ID:' | awk -F ":" '{print $2 }'`
PSUEDONAME=`lsb_release -a 2>&1 | grep 'Codename:' | awk -F ":" '{print $2 }'`
REV=`lsb_release -a 2>&1 | grep 'Release:' | awk -F ":" '{print $2 }'`
fi
fi
if [ -f /etc/UnitedLinux-release ] ; then
DIST="${DIST}[`cat /etc/UnitedLinux-release | tr "\n" ' ' | sed s/VERSION.*//`]"
fi
OS=`lowercase $OS`
DistroBasedOn=`lowercase $DistroBasedOn`
readonly OS
readonly DIST
readonly DistroBasedOn
readonly PSUEDONAME
readonly REV
readonly KERNEL
readonly MACH
fi
fi
fi
}
shootProfile
echo "OS: [$OS]"
get_os_info
echo "DIST: [$DIST]"
echo "REV: [$REV]"
echo "MACH: [$MACH]"
echo "PSUEDONAME: [$PSUEDONAME]"
echo "DistroBasedOn: [$DistroBasedOn]"
echo "KERNEL: [$KERNEL]"
echo "INSTALLATION-STOP-SUCCESS"

View File

@ -0,0 +1,19 @@
#!/bin/bash
# (c) Copyright Ascensio System Limited 2010-2015
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
USERNAME=$1;
PASSWORD=$2;
if [[ -n ${USERNAME} && -n ${PASSWORD} ]]; then
sudo docker login -u ${USERNAME} -p ${PASSWORD}
fi

View File

@ -11,24 +11,26 @@
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
SERVER_DIR=${1};
sudo mkdir -p "/app/onlyoffice/setup";
sudo mkdir -p "${SERVER_DIR}/setup";
sudo mkdir -p "/app/onlyoffice/DocumentServer/data";
sudo mkdir -p "/app/onlyoffice/DocumentServer/logs/documentserver/FileConverterService";
sudo mkdir -p "/app/onlyoffice/DocumentServer/logs/documentserver/CoAuthoringService";
sudo mkdir -p "/app/onlyoffice/DocumentServer/logs/documentserver/DocService";
sudo mkdir -p "/app/onlyoffice/DocumentServer/logs/documentserver/SpellCheckerService";
sudo mkdir -p "/app/onlyoffice/DocumentServer/logs/documentserver/LibreOfficeService";
sudo mkdir -p "${SERVER_DIR}/DocumentServer/data";
sudo mkdir -p "${SERVER_DIR}/DocumentServer/logs/documentserver/FileConverterService";
sudo mkdir -p "${SERVER_DIR}/DocumentServer/logs/documentserver/CoAuthoringService";
sudo mkdir -p "${SERVER_DIR}/DocumentServer/logs/documentserver/DocService";
sudo mkdir -p "${SERVER_DIR}/DocumentServer/logs/documentserver/SpellCheckerService";
sudo mkdir -p "${SERVER_DIR}/DocumentServer/logs/documentserver/LibreOfficeService";
sudo mkdir -p "/app/onlyoffice/MailServer/data/certs";
sudo mkdir -p "/app/onlyoffice/MailServer/logs";
sudo mkdir -p "/app/onlyoffice/MailServer/mysql";
sudo mkdir -p "${SERVER_DIR}/MailServer/data/certs";
sudo mkdir -p "${SERVER_DIR}/MailServer/logs";
sudo mkdir -p "${SERVER_DIR}/MailServer/mysql";
sudo mkdir -p "/app/onlyoffice/CommunityServer/data";
sudo mkdir -p "/app/onlyoffice/CommunityServer/logs";
sudo mkdir -p "/app/onlyoffice/CommunityServer/mysql";
sudo mkdir -p "${SERVER_DIR}/CommunityServer/data";
sudo mkdir -p "${SERVER_DIR}/CommunityServer/logs";
sudo mkdir -p "${SERVER_DIR}/CommunityServer/mysql";
sudo mkdir -p "/app/onlyoffice/ControlPanel/data";
sudo mkdir -p "/app/onlyoffice/ControlPanel/logs";
sudo mkdir -p "/app/onlyoffice/ControlPanel/mysql";
sudo chmod 777 /app -R

View File

@ -0,0 +1,20 @@
#!/bin/bash
# (c) Copyright Ascensio System Limited 2010-2015
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
EXIST=$(sudo docker network ls | awk '{print $2;}' | grep -x onlyoffice);
if [[ -z $EXIST ]]; then
sudo docker network create --driver bridge onlyoffice
fi
echo "INSTALLATION-STOP-SUCCESS"

View File

@ -0,0 +1,36 @@
#!/bin/bash
# (c) Copyright Ascensio System Limited 2010-2015
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
IMAGE_NAME=$1;
IMAGE_VERSION=$2;
if [[ -z ${IMAGE_NAME} || -z ${IMAGE_VERSION} ]]; then
echo "Docker pull argument exception: repository=$IMAGE_NAME, tag=$IMAGE_VERSION"
echo "INSTALLATION-STOP-ERROR";
exit 0;
fi
EXIST=$(sudo docker images | grep "$IMAGE_NAME" | awk '{print $2;}' | grep -x "$IMAGE_VERSION");
COUNT=1;
while [[ -z $EXIST && $COUNT -le 3 ]]; do
sudo docker pull ${IMAGE_NAME}:${IMAGE_VERSION}
EXIST=$(sudo docker images | grep "$IMAGE_NAME" | awk '{print $2;}' | grep -x "$IMAGE_VERSION");
(( COUNT++ ))
done
if [[ -z $EXIST ]]; then
echo "Docker image $IMAGE_NAME:$IMAGE_VERSION not found"
echo "INSTALLATION-STOP-ERROR";
exit 0;
fi

View File

@ -0,0 +1,39 @@
#!/bin/bash
# (c) Copyright Ascensio System Limited 2010-2015
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and limitations under the License.
# You can contact Ascensio System SIA by email at sales@onlyoffice.com
remove_container () {
CONTAINER_NAME=$1;
if [[ -z ${CONTAINER_NAME} ]]; then
echo "Empty container name"
echo "INSTALLATION-STOP-ERROR";
exit 0;
fi
echo "stop container:"
sudo docker stop ${CONTAINER_NAME};
echo "remove container:"
sudo docker rm -f ${CONTAINER_NAME};
sleep 10 #Hack for SuSe: exception "Error response from daemon: devmapper: Unknown device xxx"
echo "check removed container:"
CONTAINER_ID=$(sudo docker inspect --format='{{.Id}}' ${CONTAINER_NAME});
if [[ -n ${CONTAINER_ID} ]]; then
echo "try again remove ${CONTAINER_NAME}"
remove_container ${CONTAINER_NAME}
fi
}
remove_container $1

View File

@ -19,6 +19,7 @@
using System;
using System.Globalization;
using System.Reflection;
using System.Threading;
using System.Web.Mvc;
using System.Web.Routing;
@ -45,8 +46,8 @@ namespace OneClickInstallation
{
if (!Settings.ResourcesFromDataBase) return;
AssemblyWork.UploadResourceData(AppDomain.CurrentDomain.GetAssemblies());
AppDomain.CurrentDomain.AssemblyLoad += (s, a) => AssemblyWork.UploadResourceData(AppDomain.CurrentDomain.GetAssemblies());
DBResourceManager.PatchAssemblies();
DBResourceManager.PatchAssembly(Assembly.GetExecutingAssembly(), false);
}
protected void Application_BeginRequest(object sender, EventArgs e)

View File

@ -18,8 +18,11 @@
*/
using System;
using System.Collections.Generic;
using System.Globalization;
using System.Web;
using System.Web.Caching;
using OneClickInstallation.Classes;
using OneClickInstallation.Models;
namespace OneClickInstallation.Helpers
@ -94,12 +97,29 @@ namespace OneClickInstallation.Helpers
}
public static void ClearCache(string userId)
public static OsInfo GetOsInfo(string userId)
{
SetConnectionSettings(userId, null);
SetInstalledComponents(userId, null);
SetInstalledComponents(userId, null);
SetInstalledComponents(userId, null);
var key = "osInfo" + userId;
return CacheGet<OsInfo>(key);
}
public static void SetOsInfo(string userId, OsInfo value)
{
var key = "osInfo" + userId;
CacheSet(key, value, TimeSpan.FromDays(1));
}
public static RequestInfoModel GetRequestInfo(string userId)
{
var key = "requestInfo" + userId;
return CacheGet<RequestInfoModel>(key);
}
public static void SetRequestInfo(string userId, RequestInfoModel value)
{
var key = "requestInfo" + userId;
CacheSet(key, value, TimeSpan.FromDays(1));
}
@ -120,6 +140,40 @@ namespace OneClickInstallation.Helpers
}
public static InstallationComponentsModel GetAvailableComponents(bool enterprise)
{
var res = CacheGet<InstallationComponentsModel>(enterprise ? "availableEnterpriseComponents" : "availableComponents");
return res ?? TagHelper.InitializeAvailableTags(enterprise);
}
public static void SetAvailableComponents(bool enterprise, InstallationComponentsModel value)
{
CacheSet(enterprise ? "availableEnterpriseComponents" : "availableComponents", value, TimeSpan.FromDays(1));
}
public static void ClearUserCache(string userId)
{
SetConnectionSettings(userId, null);
SetInstalledComponents(userId, null);
SetSelectedComponents(userId, null);
SetInstallationProgress(userId, null);
SetOsInfo(userId, null);
SetRequestInfo(userId, null);
}
public static void ClearCache()
{
foreach (var lang in LangHelper.GetLanguages())
{
SetJsResuorce(new CultureInfo(lang).TwoLetterISOLanguageName, null);
}
SetAvailableComponents(true, null);
SetAvailableComponents(false, null);
}
private static T CacheGet<T>(string key)
{
var value = HttpRuntime.Cache.Get(key);

View File

@ -19,6 +19,7 @@
using System;
using System.IO;
using System.Net;
using System.Web;
using OneClickInstallation.Models;
using OneClickInstallation.Resources;
@ -65,6 +66,47 @@ namespace OneClickInstallation.Helpers
return newFileName;
}
public static string SaveFile(string url)
{
if (string.IsNullOrEmpty(url))
throw new Exception(OneClickCommonResource.ErrorFileIsNull);
var uri = new Uri(url);
var fileName = Path.GetFileName(uri.LocalPath);
if (string.IsNullOrEmpty(fileName))
throw new Exception(OneClickCommonResource.ErrorFileIsNull);
var folderPath = HttpContext.Current.Server.MapPath(DataFolder + TmpFolder);
if (!Directory.Exists(folderPath))
Directory.CreateDirectory(folderPath);
var filePath = Path.Combine(folderPath, fileName);
var index = 1;
var newFileName = fileName;
while (File.Exists(filePath))
{
newFileName = string.Format("{0} ({1}){2}", Path.GetFileNameWithoutExtension(fileName), index++, Path.GetExtension(fileName));
filePath = Path.Combine(folderPath, newFileName);
}
using (var client = new WebClient())
{
client.DownloadFile(uri, filePath);
}
return newFileName;
}
public static string GetTmpFileVirtualPath(string fileName)
{
return DataFolder + TmpFolder + "/" + fileName;
}
public static string GetFile(string fileName)
{
var filePath = Path.Combine(HttpContext.Current.Server.MapPath(DataFolder + TmpFolder), fileName);
@ -74,6 +116,14 @@ namespace OneClickInstallation.Helpers
throw new Exception(OneClickCommonResource.ErrorFileNotFound);
}
public static void RemoveFile(string filePath)
{
if (!File.Exists(filePath))
throw new Exception(OneClickCommonResource.ErrorFileNotFound);
File.Delete(filePath);
}
public static void CreateLogFile(string userId, InstallationProgressModel progressModel)
{
var fileName = "InstallSuccess.log";

View File

@ -17,11 +17,8 @@
*
*/
using System;
using System.ComponentModel;
using System.Web.Configuration;
using OneClickInstallation.Classes;
using log4net;
namespace OneClickInstallation.Helpers
{
@ -39,6 +36,7 @@ namespace OneClickInstallation.Helpers
}
}
public static string Languages
{
get { return GetAppSettings("languages", "en,de,fr,es,ru,lv,it"); }
@ -53,6 +51,7 @@ namespace OneClickInstallation.Helpers
{
get { return GetAppSettings("maxFileSize", 1048576); }
}
public static string AnalyticsFileUrl
{
@ -64,49 +63,126 @@ namespace OneClickInstallation.Helpers
get { return GetAppSettings("termsFileUrl", string.Empty); }
}
public static string SupportEmail
{
get { return GetAppSettings("supportEmail", string.Empty); }
}
public static string SourceUrl
{
get { return GetAppSettings("sourceUrl", string.Empty); }
}
public static EmailSender EmailSender
public static string DevUrl
{
get
{
try
{
var settings = GetAppSettings("emailSender", string.Empty).Split('|');
return new EmailSender
{
Host = settings[0],
Port = Convert.ToInt32(settings[1]),
Email = settings[2],
Password = settings[3],
EnableSsl = Convert.ToBoolean(settings[4])
};
}
catch (Exception ex)
{
LogManager.GetLogger("ASC").Error(ex.Message, ex);
return null;
}
}
get { return GetAppSettings("devUrl", string.Empty); }
}
public static string HelpUrl
{
get { return GetAppSettings("helpUrl", string.Empty); }
}
public static string LicenseUrl
{
get { return GetAppSettings("licenseUrl", string.Empty); }
}
public static string DockerCommunityContainerName
{
get { return GetAppSettings("docker.community-container-name", "onlyoffice-community-server"); }
}
public static string DockerDocumentContainerName
{
get { return GetAppSettings("docker.document-container-name", "onlyoffice-document-server"); }
}
public static string DockerMailContainerName
{
get { return GetAppSettings("docker.mail-container-name", "onlyoffice-mail-server"); }
}
public static string DockerControlPanelContainerName
{
get { return GetAppSettings("docker.controlpanel-container-name", "onlyoffice-control-panel"); }
}
public static string DockerCommunityImageName
{
get { return GetAppSettings("docker.community-image-name", "onlyoffice/communityserver"); }
}
public static string DockerDocumentImageName
{
get { return GetAppSettings("docker.document-image-name", "onlyoffice/documentserver"); }
}
public static string DockerMailImageName
{
get { return GetAppSettings("docker.mail-image-name", "onlyoffice/mailserver"); }
}
public static string DockerControlPanelImageName
{
get { return GetAppSettings("docker.controlpanel-image-name", "onlyoffice/controlpanel"); }
}
public static string DockerEnterpriseCommunityImageName
{
get { return GetAppSettings("docker.enterprise.community-image-name", "onlyoffice4enterprise/communityserver-ee"); }
}
public static string DockerEnterpriseDocumentImageName
{
get { return GetAppSettings("docker.enterprise.document-image-name", "onlyoffice4enterprise/documentserver-ee"); }
}
public static string DockerEnterpriseMailImageName
{
get { return GetAppSettings("docker.enterprise.mail-image-name", "onlyoffice/mailserver"); }
}
public static string DockerEnterpriseControlPanelImageName
{
get { return GetAppSettings("docker.enterprise.controlpanel-image-name", "onlyoffice4enterprise/controlpanel-ee"); }
}
public static string DockerHubLoginUrl
{
get { return GetAppSettings("dockerhub.loginUrl", "https://hub.docker.com/v2/users/login/"); }
}
public static string DockerHubTagsUrlFormat
{
get { return GetAppSettings("dockerhub.tagsUrlFormat", "https://hub.docker.com/v2/repositories/{0}/tags/"); }
}
public static string DockerHubUserName
{
get { return GetAppSettings("dockerhub.userName", string.Empty); }
}
public static string DockerHubPassword
{
get { return GetAppSettings("dockerhub.password", string.Empty); }
}
public static string CacheKey
{
get { return GetAppSettings("cacheKey", string.Empty); }
}
public const string RemoteServerDir = "/app/onlyoffice";
public const string TrialFileName = "trial.lic";
public const string InstallationStopPattern = "INSTALLATION-STOP";
public const string InstallationRebootPattern = "INSTALLATION-STOP-REBOOT";
public const string InstallationSuccessPattern = "INSTALLATION-STOP-SUCCESS";
public const string InstallationErrorPattern = "INSTALLATION-STOP-ERROR";
private static T GetAppSettings<T>(string key, T defaultValue)
{
var configSetting = WebConfigurationManager.AppSettings[key];

View File

@ -52,7 +52,7 @@ namespace OneClickInstallation.Helpers
}
public static InstallationComponentsModel Connect(string userId, ConnectionSettingsModel connectionSettings)
public static Tuple<OsInfo, InstallationComponentsModel> Connect(string userId, ConnectionSettingsModel connectionSettings)
{
using (var installationManager = new InstallationManager(userId, connectionSettings))
{

174
web/Helpers/TagHelper.cs Normal file
View File

@ -0,0 +1,174 @@
/*
*
* (c) Copyright Ascensio System Limited 2010-2015
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and limitations under the License.
*
* You can contact Ascensio System SIA by email at sales@onlyoffice.com
*
*/
using System;
using System.Collections;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using Newtonsoft.Json;
using OneClickInstallation.Classes;
using OneClickInstallation.Models;
using log4net;
namespace OneClickInstallation.Helpers
{
public class TagHelper
{
public static InstallationComponentsModel InitializeAvailableTags(bool enterprise)
{
var available = new InstallationComponentsModel
{
CommunityServerVersion = GetLatestTagName(GetImageTags(enterprise ? Settings.DockerEnterpriseCommunityImageName : Settings.DockerCommunityImageName)),
DocumentServerVersion = GetLatestTagName(GetImageTags(enterprise ? Settings.DockerEnterpriseDocumentImageName : Settings.DockerDocumentImageName)),
MailServerVersion = GetLatestTagName(GetImageTags(enterprise ? Settings.DockerEnterpriseMailImageName : Settings.DockerMailImageName)),
ControlPanelVersion = GetLatestTagName(GetImageTags(enterprise ? Settings.DockerEnterpriseControlPanelImageName : Settings.DockerControlPanelImageName)),
};
CacheHelper.SetAvailableComponents(enterprise, available);
return available;
}
public static List<ImageTag> GetImageTags(string imageName)
{
if (string.IsNullOrEmpty(imageName))
throw new ArgumentNullException("imageName");
try
{
var req = System.Net.WebRequest.Create(Settings.DockerHubLoginUrl);
req.Method = "POST";
req.ContentType = "application/json";
var credentials = string.Empty;
if (!string.IsNullOrEmpty(Settings.DockerHubUserName) && !string.IsNullOrEmpty(Settings.DockerHubPassword))
credentials = JsonConvert.SerializeObject(new
{
username = Settings.DockerHubUserName,
password = Settings.DockerHubPassword
});
var data = Encoding.ASCII.GetBytes(credentials);
req.ContentLength = data.Length;
using (var stream = req.GetRequestStream())
{
stream.Write(data, 0, data.Length);
}
string output;
using (var resp = req.GetResponse())
{
using (var stream = resp.GetResponseStream())
{
if (stream == null) return null;
var sr = new StreamReader(stream);
output = sr.ReadToEnd();
sr.Close();
}
}
var token = string.Empty;
dynamic obj;
if (!string.IsNullOrEmpty(output))
{
obj = JsonConvert.DeserializeObject<dynamic>(output);
token = obj.token;
}
req = System.Net.WebRequest.Create(string.Format(Settings.DockerHubTagsUrlFormat, imageName));
req.Method = "GET";
if(!string.IsNullOrEmpty(token))
req.Headers.Add("Authorization", "JWT " + token);
using (var resp = req.GetResponse())
{
using (var stream = resp.GetResponseStream())
{
if (stream == null) return null;
var sr = new StreamReader(stream);
output = sr.ReadToEnd();
sr.Close();
}
}
if (string.IsNullOrEmpty(output))
return null;
obj = JsonConvert.DeserializeObject<dynamic>(output);
return ((IEnumerable<dynamic>) obj.results).Select(x => new ImageTag {Name = x.name}).ToList();
}
catch (Exception ex)
{
LogManager.GetLogger("ASC").Error(ex.Message, ex);
return null;
}
}
private static string GetLatestTagName(List<ImageTag> imageTags)
{
if (imageTags == null || imageTags.Count == 0)
return null;
Version latest = null;
var unparsed = new List<string>();
foreach (var imageTag in imageTags)
{
Version current;
if (Version.TryParse(imageTag.Name, out current))
{
if (latest == null || current > latest)
latest = current;
}
else
{
unparsed.Add(imageTag.Name);
}
}
if (latest != null) return latest.ToString();
if (unparsed.Any())
{
return unparsed.Contains("latest") ? "latest" : unparsed.First();
}
return null;
}
private static string BuildBasicAuth(string username, string password)
{
var authInfo = string.Format("{0}:{1}", username, password);
return string.Format("Basic {0}", Convert.ToBase64String(Encoding.Default.GetBytes(authInfo)));
}
}
}

View File

@ -25,5 +25,7 @@ namespace OneClickInstallation.Models
public string UserName { get; set; }
public string Password { get; set; }
public string SshKey { get; set; }
public string LicenseKey { get; set; }
public bool Enterprise { get; set; }
}
}

View File

@ -21,14 +21,33 @@ namespace OneClickInstallation.Models
{
public class InstallationComponentsModel
{
public bool CommunityServer { get; set; }
public bool DocumentServer { get; set; }
public bool MailServer { get; set; }
public string CommunityServerVersion { get; set; }
public string DocumentServerVersion { get; set; }
public string MailServerVersion { get; set; }
public string MailDomain { get; set; }
public string ControlPanelVersion { get; set; }
public bool LicenseFileExist { get; set; }
public bool IsEmpty
{
get { return !CommunityServer && !DocumentServer && !MailServer; }
get
{
return string.IsNullOrEmpty(CommunityServerVersion) &&
string.IsNullOrEmpty(DocumentServerVersion) &&
string.IsNullOrEmpty(MailServerVersion) &&
string.IsNullOrEmpty(ControlPanelVersion);
}
}
public bool IsFull
{
get
{
return !string.IsNullOrEmpty(CommunityServerVersion) &&
!string.IsNullOrEmpty(DocumentServerVersion) &&
!string.IsNullOrEmpty(MailServerVersion) &&
!string.IsNullOrEmpty(ControlPanelVersion);
}
}
}
}

View File

@ -34,9 +34,9 @@ namespace OneClickInstallation.Models
GetOsInfo,
CheckPorts,
InstallDocker,
RebootServer,
InstallDocumentServer,
InstallMailServer,
InstallControlPanel,
InstallCommunityServer,
WarmUp,
End

View File

@ -0,0 +1,31 @@
/*
*
* (c) Copyright Ascensio System Limited 2010-2015
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and limitations under the License.
*
* You can contact Ascensio System SIA by email at sales@onlyoffice.com
*
*/
namespace OneClickInstallation.Models
{
public class RequestInfoModel
{
public string Name { get; set; }
public string Email { get; set; }
public string Phone { get; set; }
public string CompanyName { get; set; }
public int CompanySize { get; set; }
public string Position { get; set; }
}
}

View File

@ -42,11 +42,21 @@
<Reference Include="ASC.Common">
<HintPath>..\references\ASC.Common.dll</HintPath>
</Reference>
<Reference Include="ASC.Core.Common, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
<SpecificVersion>False</SpecificVersion>
<HintPath>..\references\ASC.Core.Common.dll</HintPath>
</Reference>
<Reference Include="ASC.Resource.Data">
<HintPath>..\references\ASC.Resource.Data.dll</HintPath>
</Reference>
<Reference Include="dotless.Core">
<HintPath>..\packages\dotless.1.3.1.0\lib\dotless.Core.dll</HintPath>
</Reference>
<Reference Include="FileConverterUtils2">
<HintPath>..\references\FileConverterUtils2.dll</HintPath>
</Reference>
<Reference Include="log4net">
<HintPath>..\packages\log4net.1.2.10\lib\2.0\log4net.dll</HintPath>
<HintPath>..\packages\log4net.2.0.3\lib\net40-client\log4net.dll</HintPath>
</Reference>
<Reference Include="Microsoft.CSharp" />
<Reference Include="Microsoft.Web.Infrastructure, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
@ -100,9 +110,8 @@
<HintPath>..\packages\Microsoft.AspNet.WebPages.2.0.20710.0\lib\net40\System.Web.WebPages.Razor.dll</HintPath>
<Private>True</Private>
</Reference>
<Reference Include="TMResourceData">
<HintPath>..\references\TMResourceData.dll</HintPath>
</Reference>
<Reference Include="System.XML" />
<Reference Include="System.Xml.Linq" />
<Reference Include="WebGrease">
<HintPath>..\packages\WebGrease.1.6.0\lib\WebGrease.dll</HintPath>
</Reference>
@ -111,15 +120,16 @@
<Content Include="404.htm" />
<Content Include="500.htm" />
<Content Include="Content\images\combo_gray.png" />
<Content Include="Content\images\coming_soon.png" />
<Content Include="Content\images\corner_top.gif" />
<Content Include="Content\images\flags.png" />
<Content Include="Content\images\loader.gif" />
<Content Include="Content\images\social.png" />
<Content Include="Content\images\logo.png" />
<Content Include="Content\images\sprite.png" />
<Content Include="Content\images\cp_features.png" />
<Content Include="Content\images\step.png" />
<Content Include="Content\images\toast_icon01.png" />
<Content Include="Content\images\toast_icon02.png" />
<Content Include="Content\images\toast_icon03.png" />
<Content Include="favicon.ico" />
<Content Include="Global.asax" />
<Content Include="Scripts\common.js" />
@ -138,11 +148,12 @@
<Compile Include="App_Start\BundleConfig.cs" />
<Compile Include="App_Start\LessTransform.cs" />
<Compile Include="App_Start\RouteConfig.cs" />
<Compile Include="Classes\ImageTag.cs" />
<Compile Include="Classes\OsInfo.cs" />
<Compile Include="Classes\EmailSender.cs" />
<Compile Include="Classes\InstallationManager.cs" />
<Compile Include="Helpers\CacheHelper.cs" />
<Compile Include="Helpers\CookieHelper.cs" />
<Compile Include="Helpers\TagHelper.cs" />
<Compile Include="Helpers\SshHelper.cs" />
<Compile Include="Helpers\FileHelper.cs" />
<Compile Include="Helpers\Settings.cs" />
@ -152,6 +163,7 @@
<DependentUpon>Global.asax</DependentUpon>
</Compile>
<Compile Include="Helpers\LangHelper.cs" />
<Compile Include="Models\RequestInfoModel.cs" />
<Compile Include="Models\InstallationComponentsModel.cs" />
<Compile Include="Models\InstallationProgressModel.cs" />
<Compile Include="Models\ConnectionSettingsModel.cs" />
@ -242,14 +254,34 @@
<Content Include="Executables\tools\check-ports.sh" />
<Content Include="Executables\tools\get-os-info.sh" />
<Content Include="Executables\run-community-server.sh" />
<Content Include="Executables\run-control-panel.sh" />
<Content Include="Executables\run-document-server.sh" />
<Content Include="Executables\run-mail-server.sh" />
<Content Include="Executables\tools\check-previous-version.sh" />
<Content Include="Executables\tools\make-dir.sh" />
<Content Include="Executables\tools\get-available-version.sh" />
</ItemGroup>
<ItemGroup>
<Content Include="Executables\tools\make-network.sh" />
</ItemGroup>
<ItemGroup>
<Content Include="Executables\tools\check-bindings.sh" />
</ItemGroup>
<ItemGroup>
<Content Include="Executables\tools\pull-image.sh" />
</ItemGroup>
<ItemGroup>
<Content Include="Executables\tools\remove-container.sh" />
</ItemGroup>
<ItemGroup>
<Content Include="Executables\tools\login-docker.sh" />
</ItemGroup>
<ItemGroup>
<Content Include="Executables\install.sh" />
</ItemGroup>
<ItemGroup>
<Content Include="Executables\restart.sh" />
</ItemGroup>
<PropertyGroup>
<VisualStudioVersion Condition="'$(VisualStudioVersion)' == ''">10.0</VisualStudioVersion>
<VSToolsPath Condition="'$(VSToolsPath)' == ''">$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)</VSToolsPath>

View File

@ -97,7 +97,7 @@ namespace OneClickInstallation.Resources {
}
/// <summary>
/// Looks up a localized string similar to © Ascensio System SIA 2015.
/// Looks up a localized string similar to © Ascensio System SIA {0}. All rights reserved.
/// </summary>
public static string Copyright {
get {
@ -115,20 +115,20 @@ namespace OneClickInstallation.Resources {
}
/// <summary>
/// Looks up a localized string similar to Empty mail sender settings.
/// Looks up a localized string similar to Open Your Web-Office.
/// </summary>
public static string EmailSenderIsNull {
public static string EnterOnlyoffice {
get {
return ResourceManager.GetString("EmailSenderIsNull", resourceCulture);
return ResourceManager.GetString("EnterOnlyoffice", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Access your ONLYOFFICE.
/// Looks up a localized string similar to File extension is incorrect.
/// </summary>
public static string Enter {
public static string ErrorFileExt {
get {
return ResourceManager.GetString("Enter", resourceCulture);
return ResourceManager.GetString("ErrorFileExt", resourceCulture);
}
}
@ -168,6 +168,24 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to License file is already exist.
/// </summary>
public static string ErrorLicenseFileExist {
get {
return ResourceManager.GetString("ErrorLicenseFileExist", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to License file is not valid.
/// </summary>
public static string ErrorLicenseFileNotValid {
get {
return ResourceManager.GetString("ErrorLicenseFileNotValid", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Progress is null.
/// </summary>
@ -177,6 +195,15 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Request Info is null.
/// </summary>
public static string ErrorRequestInfoIsNull {
get {
return ResourceManager.GetString("ErrorRequestInfoIsNull", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Community and Documents Servers are required.
/// </summary>
@ -222,6 +249,15 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Get License File.
/// </summary>
public static string GetLicenseFile {
get {
return ResourceManager.GetString("GetLicenseFile", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Google+.
/// </summary>
@ -267,15 +303,6 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Notify me.
/// </summary>
public static string Notify {
get {
return ResourceManager.GetString("Notify", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to OK.
/// </summary>

View File

@ -130,16 +130,16 @@
<value>Control panel</value>
</data>
<data name="Copyright" xml:space="preserve">
<value>© Ascensio System SIA 2015</value>
<value>© Ascensio System SIA {0}. All rights reserved</value>
</data>
<data name="Disconnect" xml:space="preserve">
<value>Disconnect</value>
</data>
<data name="EmailSenderIsNull" xml:space="preserve">
<value>Empty mail sender settings</value>
<data name="EnterOnlyoffice" xml:space="preserve">
<value>Open Your Web-Office</value>
</data>
<data name="Enter" xml:space="preserve">
<value>Access your ONLYOFFICE</value>
<data name="ErrorFileExt" xml:space="preserve">
<value>File extension is incorrect</value>
</data>
<data name="ErrorFileIsNull" xml:space="preserve">
<value>File is null</value>
@ -153,9 +153,18 @@
<data name="ErrorFilesNotTransfered" xml:space="preserve">
<value>The files are not transferred</value>
</data>
<data name="ErrorLicenseFileExist" xml:space="preserve">
<value>License file is already exist</value>
</data>
<data name="ErrorLicenseFileNotValid" xml:space="preserve">
<value>License file is not valid</value>
</data>
<data name="ErrorProgressIsNull" xml:space="preserve">
<value>Progress is null</value>
</data>
<data name="ErrorRequestInfoIsNull" xml:space="preserve">
<value>Request Info is null</value>
</data>
<data name="ErrorRequiredComponents" xml:space="preserve">
<value>Community and Documents Servers are required</value>
</data>
@ -171,6 +180,9 @@
<data name="FollowUs" xml:space="preserve">
<value>Follow us on:</value>
</data>
<data name="GetLicenseFile" xml:space="preserve">
<value>Get License File</value>
</data>
<data name="Google" xml:space="preserve">
<value>Google+</value>
</data>
@ -186,9 +198,6 @@
<data name="MetaKeywords" xml:space="preserve">
<value>online document editor, project management tool, business tools, crm system, online collaboration, cloud office, online word, documents management, online spreadsheets, online office, collaborative editing, online office application, online docs</value>
</data>
<data name="Notify" xml:space="preserve">
<value>Notify me</value>
</data>
<data name="Ok" xml:space="preserve">
<value>OK</value>
</data>

View File

@ -105,6 +105,24 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Company name.
/// </summary>
public static string CompanyNamePlaceholder {
get {
return ResourceManager.GetString("CompanyNamePlaceholder", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Company size.
/// </summary>
public static string CompanySizePlaceholder {
get {
return ResourceManager.GetString("CompanySizePlaceholder", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Connection error.
/// </summary>
@ -124,7 +142,7 @@ namespace OneClickInstallation.Resources {
}
/// <summary>
/// Looks up a localized string similar to Check connection setting and try again..
/// Looks up a localized string similar to Check the connection settings and make sure that the remote server allows SSH authentication..
/// </summary>
public static string ConnectionErrorText_2 {
get {
@ -169,11 +187,20 @@ namespace OneClickInstallation.Resources {
}
/// <summary>
/// Looks up a localized string similar to An ONLYOFFICE Installer used to automate the deployement process of ONLYOFFICE Free Edition using the Docker container technology. ONLYOFFICE Free Edition is an open source software that comprises online document editors, collaboration system and mail server, all to resolve the collaboration issues for both small and medium-sized teams..
/// Looks up a localized string similar to An ONLYOFFICE Installer used to automate the deployment process of ONLYOFFICE Community Edition using the Docker container technology. ONLYOFFICE Community Edition comprises online document editors, collaboration system and mail server, all to resolve the collaboration issues for both small and medium-sized teams..
/// </summary>
public static string ConnectionSettingsFormDescText {
public static string ConnectionSettingsFormDescText_Community {
get {
return ResourceManager.GetString("ConnectionSettingsFormDescText", resourceCulture);
return ResourceManager.GetString("ConnectionSettingsFormDescText_Community", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to An ONLYOFFICE Installer used to automate the deployment process of ONLYOFFICE Enterprise Edition using the Docker container technology. ONLYOFFICE Enterprise Edition comprises online document editors, collaboration system and mail server, all to resolve the collaboration issues for both small and medium-sized teams. ONLYOFFICE Control Panel included into this installation will help you to configure the corporate web-office quickly and easily..
/// </summary>
public static string ConnectionSettingsFormDescText_Enterprise {
get {
return ResourceManager.GetString("ConnectionSettingsFormDescText_Enterprise", resourceCulture);
}
}
@ -214,74 +241,29 @@ namespace OneClickInstallation.Resources {
}
/// <summary>
/// Looks up a localized string similar to Audit Trail.
/// Looks up a localized string similar to Control Panel.
/// </summary>
public static string ContrrolPanelFeatureAudit {
public static string ControlPanel {
get {
return ResourceManager.GetString("ContrrolPanelFeatureAudit", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Backup.
/// </summary>
public static string ContrrolPanelFeatureBackup {
get {
return ResourceManager.GetString("ContrrolPanelFeatureBackup", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to HTTPS.
/// </summary>
public static string ContrrolPanelFeatureHttps {
get {
return ResourceManager.GetString("ContrrolPanelFeatureHttps", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Update.
/// </summary>
public static string ContrrolPanelFeatureUpdate {
get {
return ResourceManager.GetString("ContrrolPanelFeatureUpdate", resourceCulture);
return ResourceManager.GetString("ControlPanel", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Control Panel.
/// </summary>
public static string ContrrolPanelHdr {
public static string ControlPanelHdr {
get {
return ResourceManager.GetString("ContrrolPanelHdr", resourceCulture);
return ResourceManager.GetString("ControlPanelHdr", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to ONLYOFFICE Control Panel is a new way to manage and configure your server in one click. It offers features like ....
/// Looks up a localized string similar to ONLYOFFICE Control Panel is a set of automation tools designed to simplify the web-office settings management, such as HTTPS, Updates, Rebranding, LDAP, Data Backup and Restore, Health Check, Login History and Audit Trail..
/// </summary>
public static string ContrrolPanelText {
public static string ControlPanelText_Enterprise {
get {
return ResourceManager.GetString("ContrrolPanelText", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Customize settings*.
/// </summary>
public static string CustomStepText {
get {
return ResourceManager.GetString("CustomStepText", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to * Advanced configuration settings provided on commercial basis.
/// </summary>
public static string CustomStepTitleText {
get {
return ResourceManager.GetString("CustomStepTitleText", resourceCulture);
return ResourceManager.GetString("ControlPanelText_Enterprise", resourceCulture);
}
}
@ -313,7 +295,7 @@ namespace OneClickInstallation.Resources {
}
/// <summary>
/// Looks up a localized string similar to Enter your email.
/// Looks up a localized string similar to Email.
/// </summary>
public static string EmailPlaceholder {
get {
@ -321,6 +303,24 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to {0} employees.
/// </summary>
public static string EmployeesCount {
get {
return ResourceManager.GetString("EmployeesCount", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to More than {0} employees.
/// </summary>
public static string EmployeesMoreThanCount {
get {
return ResourceManager.GetString("EmployeesMoreThanCount", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Installation error.
/// </summary>
@ -339,6 +339,24 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to FAQ.
/// </summary>
public static string FAQ {
get {
return ResourceManager.GetString("FAQ", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Get trial License File.
/// </summary>
public static string GetLicenseFile {
get {
return ResourceManager.GetString("GetLicenseFile", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Hardware requirements.
/// </summary>
@ -456,6 +474,15 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Installing Control Panel.
/// </summary>
public static string InstallationProgressStep_InstallControlPanel {
get {
return ResourceManager.GetString("InstallationProgressStep_InstallControlPanel", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Installing Docker service.
/// </summary>
@ -483,15 +510,6 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Rebooting the server.
/// </summary>
public static string InstallationProgressStep_RebootServer {
get {
return ResourceManager.GetString("InstallationProgressStep_RebootServer", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Starting the installstion.
/// </summary>
@ -537,6 +555,33 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Learn more.
/// </summary>
public static string LearnMore {
get {
return ResourceManager.GetString("LearnMore", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to License File.
/// </summary>
public static string LicenseFile {
get {
return ResourceManager.GetString("LicenseFile", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Upload License File.
/// </summary>
public static string LicensePlaceholder {
get {
return ResourceManager.GetString("LicensePlaceholder", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Enter Domain Name.
/// </summary>
@ -600,6 +645,15 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Name.
/// </summary>
public static string NamePlaceholder {
get {
return ResourceManager.GetString("NamePlaceholder", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to CoreOS 647.0.0 (stable).
/// </summary>
@ -619,7 +673,7 @@ namespace OneClickInstallation.Resources {
}
/// <summary>
/// Looks up a localized string similar to any other distributive with kernel version 3.19.
/// Looks up a localized string similar to any other distributive with kernel version 3.10 or later.
/// </summary>
public static string OperatingSystemOther {
get {
@ -654,6 +708,33 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Phone.
/// </summary>
public static string PhonePlaceholder {
get {
return ResourceManager.GetString("PhonePlaceholder", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Position.
/// </summary>
public static string PositionPlaceholder {
get {
return ResourceManager.GetString("PositionPlaceholder", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Request form.
/// </summary>
public static string RequestForm {
get {
return ResourceManager.GetString("RequestForm", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Minimum server requirements:.
/// </summary>
@ -664,7 +745,7 @@ namespace OneClickInstallation.Resources {
}
/// <summary>
/// Looks up a localized string similar to Congratulations, the installation process is successfully completed!.
/// Looks up a localized string similar to Congratulations! You have successfully installed ONLYOFFICE!.
/// </summary>
public static string ServerSettingsFormDescHdr {
get {
@ -673,20 +754,20 @@ namespace OneClickInstallation.Resources {
}
/// <summary>
/// Looks up a localized string similar to Control Panel.
/// Looks up a localized string similar to Your corporate web-office is ready..
/// </summary>
public static string ServerSettingsFormHdr {
public static string ServerSettingsFormDescText_1 {
get {
return ResourceManager.GetString("ServerSettingsFormHdr", resourceCulture);
return ResourceManager.GetString("ServerSettingsFormDescText_1", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to The Control Panel is in beta stage and will be available soon. Enter your email below to be the first to learn about the release..
/// Looks up a localized string similar to To start working right now, click the Open Your Web-Office button..
/// </summary>
public static string ServerSettingsFormText {
public static string ServerSettingsFormDescText_2 {
get {
return ResourceManager.GetString("ServerSettingsFormText", resourceCulture);
return ResourceManager.GetString("ServerSettingsFormDescText_2", resourceCulture);
}
}
@ -735,24 +816,6 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Community and Document Server will be installed by default. Select Mail Server if you need it..
/// </summary>
public static string SetupFormText {
get {
return ResourceManager.GetString("SetupFormText", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to We recommended that you install Mail Server together with other components. In case you decide to install it later you will need to remove all previously installed ONLYOFFICE components for successful installation..
/// </summary>
public static string SetupMailServerDesc {
get {
return ResourceManager.GetString("SetupMailServerDesc", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Software requirements.
/// </summary>
@ -799,11 +862,20 @@ namespace OneClickInstallation.Resources {
}
/// <summary>
/// Looks up a localized string similar to You need to manually remove previously installed ONLYOFFICE components before you can continue installation..
/// Looks up a localized string similar to After the correct filling in of the request we automatically generate the license file for the trial version, which will be available to you within 30 days..
/// </summary>
public static string UpdadeSetupOptionsDesc {
public static string TrialDescText {
get {
return ResourceManager.GetString("UpdadeSetupOptionsDesc", resourceCulture);
return ResourceManager.GetString("TrialDescText", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Your license file has been successfully created and will be automatically inserted in the field..
/// </summary>
public static string TrialReadyText {
get {
return ResourceManager.GetString("TrialReadyText", resourceCulture);
}
}
@ -815,5 +887,14 @@ namespace OneClickInstallation.Resources {
return ResourceManager.GetString("UserNamePlaceholder", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Start using.
/// </summary>
public static string UsingStepText {
get {
return ResourceManager.GetString("UsingStepText", resourceCulture);
}
}
}
}

View File

@ -124,7 +124,7 @@
<value>Could not connect to the server.</value>
</data>
<data name="ConnectionErrorText_2" xml:space="preserve">
<value>Check connection setting and try again.</value>
<value>Check the connection settings and make sure that the remote server allows SSH authentication.</value>
</data>
<data name="ConnectionSettingsFormText" xml:space="preserve">
<value>Before you start the installation process, you need to connect to your server. Fill out the form below and click the 'CONNECT' button.</value>
@ -213,9 +213,6 @@
<data name="ConnectStepText" xml:space="preserve">
<value>Connect your server</value>
</data>
<data name="CustomStepText" xml:space="preserve">
<value>Customize settings*</value>
</data>
<data name="DocumentServer" xml:space="preserve">
<value>Document Server</value>
</data>
@ -231,9 +228,6 @@
<data name="SetupFormHdr" xml:space="preserve">
<value>Setup Options</value>
</data>
<data name="SetupFormText" xml:space="preserve">
<value>Community and Document Server will be installed by default. Select Mail Server if you need it.</value>
</data>
<data name="MailServer" xml:space="preserve">
<value>Mail Server</value>
</data>
@ -285,9 +279,6 @@
<data name="InstallationProgressStep_InstallDocker" xml:space="preserve">
<value>Installing Docker service</value>
</data>
<data name="InstallationProgressStep_RebootServer" xml:space="preserve">
<value>Rebooting the server</value>
</data>
<data name="InstallationProgressStep_InstallDocumentServer" xml:space="preserve">
<value>Installing Document Server</value>
</data>
@ -306,35 +297,8 @@
<data name="SetupFormDescProgressText" xml:space="preserve">
<value>The ONLYOFFICE installation process may take a few minutes. Please wait.</value>
</data>
<data name="ContrrolPanelFeatureBackup" xml:space="preserve">
<value>Backup</value>
</data>
<data name="ContrrolPanelFeatureHttps" xml:space="preserve">
<value>HTTPS</value>
</data>
<data name="ContrrolPanelFeatureAudit" xml:space="preserve">
<value>Audit Trail</value>
</data>
<data name="ContrrolPanelFeatureUpdate" xml:space="preserve">
<value>Update</value>
</data>
<data name="ContrrolPanelHdr" xml:space="preserve">
<value>Control Panel</value>
</data>
<data name="ContrrolPanelText" xml:space="preserve">
<value>ONLYOFFICE Control Panel is a new way to manage and configure your server in one click. It offers features like ...</value>
</data>
<data name="EmailPlaceholder" xml:space="preserve">
<value>Enter your email</value>
</data>
<data name="ServerSettingsFormDescHdr" xml:space="preserve">
<value>Congratulations, the installation process is successfully completed!</value>
</data>
<data name="ServerSettingsFormHdr" xml:space="preserve">
<value>Control Panel</value>
</data>
<data name="ServerSettingsFormText" xml:space="preserve">
<value>The Control Panel is in beta stage and will be available soon. Enter your email below to be the first to learn about the release.</value>
<value>Congratulations! You have successfully installed ONLYOFFICE!</value>
</data>
<data name="SourceDesc" xml:space="preserve">
<value>ONLYOFFICE Installer is distributed under the Apache license. The source code is listed on GitHub.</value>
@ -342,31 +306,94 @@
<data name="SourceLinkText" xml:space="preserve">
<value>Fork me on GitHub</value>
</data>
<data name="CustomStepTitleText" xml:space="preserve">
<value>* Advanced configuration settings provided on commercial basis</value>
</data>
<data name="SetupFormDescHdr" xml:space="preserve">
<value>Congratulations! Server connection established successfully.</value>
</data>
<data name="ConnectionSettingsConnectedFormDescText" xml:space="preserve">
<value>To connect to a different server, you will need to disconnect first.</value>
</data>
<data name="ConnectionSettingsFormDescText" xml:space="preserve">
<value>An ONLYOFFICE Installer used to automate the deployement process of ONLYOFFICE Free Edition using the Docker container technology. ONLYOFFICE Free Edition is an open source software that comprises online document editors, collaboration system and mail server, all to resolve the collaboration issues for both small and medium-sized teams.</value>
</data>
<data name="SetupFormDescText" xml:space="preserve">
<value>Read the information below to choose the ONLYOFFICE components that suit your needs best.</value>
</data>
<data name="UpdadeSetupOptionsDesc" xml:space="preserve">
<value>You need to manually remove previously installed ONLYOFFICE components before you can continue installation.</value>
</data>
<data name="SetupMailServerDesc" xml:space="preserve">
<value>We recommended that you install Mail Server together with other components. In case you decide to install it later you will need to remove all previously installed ONLYOFFICE components for successful installation.</value>
</data>
<data name="OperatingSystemCoreOS" xml:space="preserve">
<value>CoreOS 647.0.0 (stable)</value>
</data>
<data name="OperatingSystemOther" xml:space="preserve">
<value>any other distributive with kernel version 3.19</value>
<value>any other distributive with kernel version 3.10 or later</value>
</data>
<data name="FAQ" xml:space="preserve">
<value>FAQ</value>
</data>
<data name="LicensePlaceholder" xml:space="preserve">
<value>Upload License File</value>
</data>
<data name="InstallationProgressStep_InstallControlPanel" xml:space="preserve">
<value>Installing Control Panel</value>
</data>
<data name="ControlPanel" xml:space="preserve">
<value>Control Panel</value>
</data>
<data name="ConnectionSettingsFormDescText_Enterprise" xml:space="preserve">
<value>An ONLYOFFICE Installer used to automate the deployment process of ONLYOFFICE Enterprise Edition using the Docker container technology. ONLYOFFICE Enterprise Edition comprises online document editors, collaboration system and mail server, all to resolve the collaboration issues for both small and medium-sized teams. ONLYOFFICE Control Panel included into this installation will help you to configure the corporate web-office quickly and easily.</value>
</data>
<data name="ControlPanelHdr" xml:space="preserve">
<value>Control Panel</value>
</data>
<data name="ControlPanelText_Enterprise" xml:space="preserve">
<value>ONLYOFFICE Control Panel is a set of automation tools designed to simplify the web-office settings management, such as HTTPS, Updates, Rebranding, LDAP, Data Backup and Restore, Health Check, Login History and Audit Trail.</value>
</data>
<data name="UsingStepText" xml:space="preserve">
<value>Start using</value>
</data>
<data name="ServerSettingsFormDescText_1" xml:space="preserve">
<value>Your corporate web-office is ready.</value>
</data>
<data name="ServerSettingsFormDescText_2" xml:space="preserve">
<value>To start working right now, click the Open Your Web-Office button.</value>
</data>
<data name="LearnMore" xml:space="preserve">
<value>Learn more</value>
</data>
<data name="CompanyNamePlaceholder" xml:space="preserve">
<value>Company name</value>
</data>
<data name="CompanySizePlaceholder" xml:space="preserve">
<value>Company size</value>
</data>
<data name="EmailPlaceholder" xml:space="preserve">
<value>Email</value>
</data>
<data name="EmployeesCount" xml:space="preserve">
<value>{0} employees</value>
</data>
<data name="EmployeesMoreThanCount" xml:space="preserve">
<value>More than {0} employees</value>
</data>
<data name="GetLicenseFile" xml:space="preserve">
<value>Get trial License File</value>
</data>
<data name="LicenseFile" xml:space="preserve">
<value>License File</value>
</data>
<data name="NamePlaceholder" xml:space="preserve">
<value>Name</value>
</data>
<data name="PhonePlaceholder" xml:space="preserve">
<value>Phone</value>
</data>
<data name="PositionPlaceholder" xml:space="preserve">
<value>Position</value>
</data>
<data name="RequestForm" xml:space="preserve">
<value>Request form</value>
</data>
<data name="TrialDescText" xml:space="preserve">
<value>After the correct filling in of the request we automatically generate the license file for the trial version, which will be available to you within 30 days.</value>
</data>
<data name="TrialReadyText" xml:space="preserve">
<value>Your license file has been successfully created and will be automatically inserted in the field.</value>
</data>
<data name="ConnectionSettingsFormDescText_Community" xml:space="preserve">
<value>An ONLYOFFICE Installer used to automate the deployment process of ONLYOFFICE Community Edition using the Docker container technology. ONLYOFFICE Community Edition comprises online document editors, collaboration system and mail server, all to resolve the collaboration issues for both small and medium-sized teams.</value>
</data>
</root>

View File

@ -60,15 +60,6 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Email sended.
/// </summary>
public static string EmailSendedMsg {
get {
return ResourceManager.GetString("EmailSendedMsg", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Currently only supports 64bit OS&apos;s.
/// </summary>
@ -88,7 +79,7 @@ namespace OneClickInstallation.Resources {
}
/// <summary>
/// Looks up a localized string similar to The following ports must be open: 80, 443 (25 for Mail Server).
/// Looks up a localized string similar to The required ports are closed.
/// </summary>
public static string ErrorInstallation3 {
get {
@ -132,6 +123,42 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to To perform this action you must be logged in with root rights.
/// </summary>
public static string ErrorInstallation8 {
get {
return ResourceManager.GetString("ErrorInstallation8", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Cannot create trial license. Invalid input parameter..
/// </summary>
public static string ErrorInstallationExternal1 {
get {
return ResourceManager.GetString("ErrorInstallationExternal1", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Cannot create trial license.  An internal error is occured..
/// </summary>
public static string ErrorInstallationExternal2 {
get {
return ResourceManager.GetString("ErrorInstallationExternal2", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Cannot create trial license. The hostname has been assigned to another email address..
/// </summary>
public static string ErrorInstallationExternal3 {
get {
return ResourceManager.GetString("ErrorInstallationExternal3", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Invalid domain name.
/// </summary>
@ -168,15 +195,6 @@ namespace OneClickInstallation.Resources {
}
}
/// <summary>
/// Looks up a localized string similar to Reboot the server.
/// </summary>
public static string InstallationStepRebootMsg {
get {
return ResourceManager.GetString("InstallationStepRebootMsg", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Please wait....
/// </summary>
@ -185,23 +203,5 @@ namespace OneClickInstallation.Resources {
return ResourceManager.GetString("LoaderMsg", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to I want to be notified about the release of a new product. My email: {0}.
/// </summary>
public static string NotyfyEmailBody {
get {
return ResourceManager.GetString("NotyfyEmailBody", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Control Panel Subscription.
/// </summary>
public static string NotyfyEmailSubject {
get {
return ResourceManager.GetString("NotyfyEmailSubject", resourceCulture);
}
}
}
}

View File

@ -117,9 +117,6 @@
<resheader name="writer">
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
</resheader>
<data name="EmailSendedMsg" xml:space="preserve">
<value>Email sended</value>
</data>
<data name="ErrorInstallation1" xml:space="preserve">
<value>Currently only supports 64bit OS's</value>
</data>
@ -127,7 +124,7 @@
<value>Not supported OS</value>
</data>
<data name="ErrorInstallation3" xml:space="preserve">
<value>The following ports must be open: 80, 443 (25 for Mail Server)</value>
<value>The required ports are closed</value>
</data>
<data name="ErrorInstallation4" xml:space="preserve">
<value>Please, set hostname for mail server</value>
@ -141,6 +138,18 @@
<data name="ErrorInstallation7" xml:space="preserve">
<value>Kernel version not supported</value>
</data>
<data name="ErrorInstallation8" xml:space="preserve">
<value>To perform this action you must be logged in with root rights</value>
</data>
<data name="ErrorInstallationExternal1" xml:space="preserve">
<value>Cannot create trial license. Invalid input parameter.</value>
</data>
<data name="ErrorInstallationExternal2" xml:space="preserve">
<value>Cannot create trial license.  An internal error is occured.</value>
</data>
<data name="ErrorInstallationExternal3" xml:space="preserve">
<value>Cannot create trial license. The hostname has been assigned to another email address.</value>
</data>
<data name="ErrorInvalidDomainName" xml:space="preserve">
<value>Invalid domain name</value>
</data>
@ -153,16 +162,7 @@
<data name="InstallationStepProcessMsg" xml:space="preserve">
<value>In the process</value>
</data>
<data name="InstallationStepRebootMsg" xml:space="preserve">
<value>Reboot the server</value>
</data>
<data name="LoaderMsg" xml:space="preserve">
<value>Please wait...</value>
</data>
<data name="NotyfyEmailBody" xml:space="preserve">
<value>I want to be notified about the release of a new product. My email: {0}</value>
</data>
<data name="NotyfyEmailSubject" xml:space="preserve">
<value>Control Panel Subscription</value>
</data>
</root>

View File

@ -156,8 +156,8 @@ var Common = (function () {
return {
show: function (popupId, width, height, marginLeft, marginTop) {
width = width || 362;
height = height || 325;
width = width || 460;
height = height || 300;
marginLeft = marginLeft || 0;
marginTop = marginTop || 0;
@ -171,7 +171,79 @@ var Common = (function () {
};
}();
var getKeyCode = function(event) {
var selectorListener = function () {
var $selectors = $('.custom-select');
var init = function () {
$selectors.on('click', showSelectOptions);
$selectors.on('click', '.custom-select-option', selectOption);
$selectors.on('focus', '.custom-select-value', function () { this.blur(); });
$("body").on("click", function (event) {
var target = (event.target) ? event.target : event.srcElement,
element = $(target);
if (!element.is('.custom-select') && !element.is('.custom-select-value') && !element.is('.custom-select-switch')) {
$selectors.find('.custom-select-options').hide();
} else {
var curBox = element.is('.custom-select') ? element : element.parents('.custom-select:first');
$selectors.not(curBox).find('.custom-select-options').hide();
}
});
};
function showSelectOptions() {
var $selector = $(this);
var $options = $selector.find('.custom-select-options');
if ($options.is(':visible')) {
$options.hide();
$options.css('top', 0);
$options.css('left', 0);
} else {
var offset = $selector.position();
if ($options.is('.top')) {
$options.css('top', offset.top - $options.outerHeight() - 3 + 'px');
$options.css('left', offset.left + $selector.outerWidth() - $options.outerWidth() + 'px');
} else {
$options.css('top', offset.top + $selector.outerHeight() + 3 + 'px');
$options.css('left', offset.left + $selector.outerWidth() - $options.outerWidth() + 'px');
}
$options.show();
}
}
function selectOption() {
var $option = $(this);
var $select = $option.closest('.custom-select');
$select.find('.custom-select-value').val($option.text());
$select.attr('data-value', $option.attr('data-value'));
$option.closest('.custom-select-options').hide();
$option.siblings('.custom-select-option').removeClass('selected');
$option.addClass('selected');
}
var set = function (select, value) {
if (!select.is(".custom-select")) {
return;
}
select.find(".custom-select-option[data-value=\"" + value + "\"]").click();
};
return {
init: init,
set: set,
};
}();
var getKeyCode = function (event) {
var code = null;
if (event.keyCode)
@ -182,10 +254,28 @@ var Common = (function () {
return code;
};
var getUrlParam = function (paramName) {
var urlParams = {};
if (location.search) {
var queryParts = location.search.substring(1).split("&");
for (var i = 0; i < queryParts.length; i++) {
var keyValuePair = queryParts[i].split("=");
if (!keyValuePair[0]) continue;
urlParams[keyValuePair[0]] = keyValuePair[1];
}
}
return urlParams.hasOwnProperty(paramName) ? urlParams[paramName] : null;
};
return {
loader: loader,
blockUI: blockUI,
getKeyCode: getKeyCode
selectorListener: selectorListener,
getKeyCode: getKeyCode,
getUrlParam: getUrlParam
};
})($);

File diff suppressed because it is too large Load Diff

View File

@ -16,18 +16,21 @@
<div class="popup-caption">
<div class="popup-error"></div>
@OneClickHomePageResource.ConnectionErrorHdr
<div class="popup-close">x</div>
<div class="popup-close"></div>
</div>
<div class="popup-body">
<div class="bottom-indent">
<div class="error-message"></div>
<div class="default-message">
@OneClickHomePageResource.ConnectionErrorText_1
<br/>
@OneClickHomePageResource.ConnectionErrorText_2
<div>
@OneClickHomePageResource.ConnectionErrorText_1<br/>
@OneClickHomePageResource.ConnectionErrorText_2
</div>
<br>
<a href="@Settings.HelpUrl" target="_blank" class="underline">@OneClickHomePageResource.LearnMore</a>
</div>
</div>
<a class="button dark small okbtn">@OneClickCommonResource.Ok</a>
<a class="button black okbtn">@OneClickCommonResource.Ok</a>
</div>
</div>
@ -35,7 +38,7 @@
<div class="popup-caption">
<div class="popup-error"></div>
@OneClickHomePageResource.InstallationErrorHdr
<div class="popup-close">x</div>
<div class="popup-close"></div>
</div>
<div class="popup-body">
<div class="bottom-indent">
@ -43,9 +46,9 @@
<div class="default-message">@OneClickHomePageResource.InstallationErrorText</div>
<br>
<span>@OneClickHomePageResource.ContactSupport&nbsp;</span>
<a href="mailto:@Settings.SupportEmail" class="underline">@Settings.SupportEmail</a>
<a href="@Settings.DevUrl" target="_blank" class="underline">@Settings.DevUrl</a>
</div>
<a class="button dark small okbtn">@OneClickCommonResource.Ok</a>
<a class="button black okbtn">@OneClickCommonResource.Ok</a>
</div>
</div>
@ -53,7 +56,7 @@
<div class="popup-caption">
<div class="popup-error"></div>
@OneClickHomePageResource.ExistVersionErrorHdr
<div class="popup-close">x</div>
<div class="popup-close"></div>
</div>
<div class="popup-body">
<div class="bottom-indent">
@ -64,30 +67,80 @@
</div>
<br>
<span>@OneClickHomePageResource.ContactSupport&nbsp;</span>
<a href="mailto:@Settings.SupportEmail" class="underline">@Settings.SupportEmail</a>
<a href="@Settings.DevUrl" target="_blank" class="underline">@Settings.DevUrl</a>
</div>
</div>
<a class="button dark small okbtn">@OneClickCommonResource.Ok</a>
<a class="button black okbtn">@OneClickCommonResource.Ok</a>
</div>
</div>
@if (ViewBag.Enterprise)
{
<div id="trialPop" class="popup">
<div class="popup-caption">
@OneClickHomePageResource.RequestForm
<div class="popup-close"></div>
</div>
<div class="popup-body">
<div class="disconnected" style="height: 480px;">
<div class="bottom-indent label">
@OneClickHomePageResource.TrialDescText
</div>
<div class="bottom-indent">
<input id="name" type="text" class="group-top" placeholder="@OneClickHomePageResource.NamePlaceholder" />
<input id="email" type="text" class="group-center" placeholder="@OneClickHomePageResource.EmailPlaceholder" />
<input id="phone" type="text" class="group-center" placeholder="@OneClickHomePageResource.PhonePlaceholder" />
<input id="companyName" type="text" class="group-center" placeholder="@OneClickHomePageResource.CompanyNamePlaceholder" />
<div class="custom-select group-center">
<input id="companySize" type="text" class="custom-select-value" placeholder="@OneClickHomePageResource.CompanySizePlaceholder" readonly="readonly"/>
<div class="custom-select-switch"></div>
<div class="custom-select-options">
<div class="custom-select-options-inner">
<div class="custom-select-option" data-value="5">@String.Format(OneClickHomePageResource.EmployeesCount, "1 - 5")</div>
<div class="custom-select-option" data-value="14">@String.Format(OneClickHomePageResource.EmployeesCount, "6 - 14")</div>
<div class="custom-select-option" data-value="64">@String.Format(OneClickHomePageResource.EmployeesCount, "15 - 64")</div>
<div class="custom-select-option" data-value="350">@String.Format(OneClickHomePageResource.EmployeesCount, "65 - 350")</div>
<div class="custom-select-option" data-value="1499">@String.Format(OneClickHomePageResource.EmployeesCount, "351 - 1499")</div>
<div class="custom-select-option" data-value="1500">@String.Format(OneClickHomePageResource.EmployeesMoreThanCount, "1500")</div>
</div>
</div>
</div>
<input id="position" type="text" class="group-bottom" placeholder="@OneClickHomePageResource.PositionPlaceholder" />
</div>
<a id="trialBtn" class="button black">@OneClickCommonResource.GetLicenseFile</a>
</div>
<div class="connected display-none" style="height: 480px;">
<h1 class="blue bottom-indent">@OneClickHomePageResource.TrialReadyText</h1>
<a class="button green okbtn">@OneClickCommonResource.Ok</a>
</div>
</div>
</div>
}
@section scripts {
@Scripts.Render("~/bundles/homepage")
<script>
$(function() {
$(function () {
ActionUrl.UploadFile = '@Url.Action("UploadFile", "Home")';
ActionUrl.Connect = '@Url.Action("Connect", "Home")';
ActionUrl.StartInstall = '@Url.Action("StartInstall", "Home")';
ActionUrl.InstallProgress = '@Url.Action("InstallProgress", "Home")';
SetupInfo.connectionSettings = JSON.parse(@Html.Raw(Json.Encode(ViewBag.ConnectionSettings)));
SetupInfo.availableComponents = JSON.parse(@Html.Raw(Json.Encode(ViewBag.AvailableComponents)));
SetupInfo.installedComponents = JSON.parse(@Html.Raw(Json.Encode(ViewBag.InstalledComponents)));
SetupInfo.selectedComponents = JSON.parse(@Html.Raw(Json.Encode(ViewBag.SelectedComponents)));
SetupInfo.installationProgress = JSON.parse(@Html.Raw(Json.Encode(ViewBag.InstallationProgress)));
SetupInfo.osInfo = JSON.parse(@Html.Raw(Json.Encode(ViewBag.OsInfo)));
SetupInfo.trialFileName = '@Settings.TrialFileName';
SetupInfo.enterprise = Boolean(@(ViewBag.Enterprise ? 1 : 0));
InstallManager.init();
InstallManager.init('@Url.Action("UploadFile", "Home")',
'@Url.Action("Connect", "Home")',
'@Url.Action("StartInstall", "Home")',
'@Url.Action("InstallProgress", "Home")',
'@Url.Action("SendEmail", "Home")');
});
</script>
}

View File

@ -9,45 +9,58 @@
<p class="label">@OneClickHomePageResource.ConnectionSettingsFormText</p>
<div id="connectionFieldsForm">
<div class="bottom-indent">
<input id="host" type="text" class="group-top" placeholder="@OneClickHomePageResource.IPAddressPlaceholder" />
<input id="userName" type="text" class="group-bottom" placeholder="@OneClickHomePageResource.UserNamePlaceholder" />
</div>
<div class="bottom-indent">
<input id="host" type="text" class="group-top" placeholder="@OneClickHomePageResource.IPAddressPlaceholder" />
<input id="userName" type="text" class="group-bottom" placeholder="@OneClickHomePageResource.UserNamePlaceholder" />
<div class="bottom-indent-small">
<div id="keyType" class="custom-radio checked" data-name="authType">
<div class="icon"></div>
<span class="label">@OneClickHomePageResource.SSHKey</span>
</div>
<div class="bottom-indent">
<div id="keyType" class="custom-radio checked" data-name="authType">
<div class="icon"></div>
<span class="label">@OneClickHomePageResource.SSHKey</span>
</div>
<div id="passwordType" class="custom-radio" data-name="authType">
<div class="icon"></div>
<span class="label">@OneClickHomePageResource.Password</span>
</div>
<div id="passwordType" class="custom-radio" data-name="authType">
<div class="icon"></div>
<span class="label">@OneClickHomePageResource.Password</span>
</div>
</div>
<div class="bottom-indent position-relative">
<input id="sshKey" type="text" class="single" readonly="readonly" placeholder="@OneClickHomePageResource.SSHKeyPlaceholder" style="padding-right: 64px;"/>
<div class="bottom-indent position-relative">
<input id="sshKey" type="text" class="single" readonly="readonly" placeholder="@OneClickHomePageResource.SSHKeyPlaceholder" style="padding-right: 64px;"/>
<div class="upload-container">
<input type="file" name="file" id="sshFile">
<a class="button black">+</a>
</div>
</div>
<div class="bottom-indent display-none">
<input id="password" type="password" class="single" placeholder="@OneClickHomePageResource.PasswordPlaceholder" />
</div>
@if (ViewBag.Enterprise)
{
<div class="bottom-indent-small semibold">@OneClickHomePageResource.LicenseFile</div>
<div class="bottom-indent-small position-relative">
<input id="licenseKey" type="text" class="single" readonly="readonly" placeholder="@OneClickHomePageResource.LicensePlaceholder" style="padding-right: 64px;"/>
<div class="upload-container">
<input type="file" name="file" id="sshFile">
<input type="file" name="file" id="licenseFile">
<a class="button black">+</a>
</div>
</div>
<div class="bottom-indent display-none">
<input id="password" type="password" class="single" placeholder="@OneClickHomePageResource.PasswordPlaceholder" />
</div>
<div class="bottom-indent">
<a id="connectBtn" class="button green disabled">@OneClickCommonResource.Connect</a>
</div>
<div id="termsBlock" class="bottom-indent gray describe">
@OneClickHomePageResource.AcceptTermsText<br />
<a class="blue underline" href="@Settings.TermsFileUrl" target="_blank">@OneClickHomePageResource.AcceptTermsLinkText</a>
<a id="showTrialPop" class="blue underline label">@OneClickHomePageResource.GetLicenseFile</a>
</div>
}
<div class="bottom-indent">
<a id="connectBtn" class="button green disabled">@OneClickCommonResource.Connect</a>
</div>
<div id="termsBlock" class="bottom-indent gray describe">
@OneClickHomePageResource.AcceptTermsText<br />
<a class="blue underline" href="@Settings.TermsFileUrl" target="_blank">@OneClickHomePageResource.AcceptTermsLinkText</a>
</div>
</div>
@ -68,24 +81,22 @@
<h2 class="blue">@OneClickHomePageResource.SetupFormHdr</h2>
<p id="setupInfoText" class="label">@OneClickHomePageResource.SetupFormText</p>
<div class="bottom-indent">
<div id="installCommunityServerCbx" class="custom-checkbox checked disabled">
<div id="installCommunityServerCbx" class="custom-checkbox">
<div class="icon"></div>
<span class="label">@OneClickHomePageResource.CommunityServer</span>
</div>
</div>
<div class="bottom-indent">
<div id="installDocumentServerCbx" class="custom-checkbox checked disabled">
<div id="installDocumentServerCbx" class="custom-checkbox">
<div class="icon"></div>
<span class="label">@OneClickHomePageResource.DocumentServer</span>
</div>
</div>
<div class="bottom-indent">
<div id="installMailServerCbx" class="custom-checkbox checked">
<div id="installMailServerCbx" class="custom-checkbox">
<div class="icon"></div>
<span class="label">@OneClickHomePageResource.MailServer</span>
</div>
@ -94,34 +105,23 @@
<div class="bottom-indent">
<input id="mailDomain" type="text" class="single" placeholder="@OneClickHomePageResource.MailDomainPlaceholder" />
</div>
<p id="mailServerSetupDesc" class="label display-none">@OneClickHomePageResource.SetupMailServerDesc</p>
<p id="updadeSetupOptionsDesc" class="label display-none">@OneClickHomePageResource.UpdadeSetupOptionsDesc</p>
@if (ViewBag.Enterprise)
{
<div class="bottom-indent" style="margin-top: 42px;">
<div id="installControlPanelCbx" class="custom-checkbox">
<div class="icon"></div>
<span class="label">@OneClickHomePageResource.ControlPanel</span>
</div>
</div>
}
<div class="bottom-indent">
<a id="installbtn" class="button green disabled">@OneClickCommonResource.Install</a>
<a id="disconnectBtn1" class="button green disabled display-none">@OneClickCommonResource.Disconnect</a>
<a id="installBtn" class="button green disabled">@OneClickCommonResource.Install</a>
</div>
</div>
<div id="settingsForm" class="form display-none">
<h2 class="blue">@OneClickHomePageResource.ServerSettingsFormHdr</h2>
<p class="label">@OneClickHomePageResource.ServerSettingsFormText</p>
<div id="notificationFieldsForm">
<div class="bottom-indent">
<input id="email" type="text" class="single" placeholder="@OneClickHomePageResource.EmailPlaceholder" />
</div>
<div class="bottom-indent">
<a id="notifybtn" class="button green disabled">@OneClickCommonResource.Notify</a>
</div>
</div>
</div>

View File

@ -5,16 +5,22 @@
<div class="disconnected display-none">
<h1 class="blue">@OneClickHomePageResource.ConnectionSettingsFormDescHdr</h1>
<p class="bottom-indent-big">@OneClickHomePageResource.ConnectionSettingsFormDescText</p>
@if (ViewBag.Enterprise)
{
<p class="bottom-indent-big">@OneClickHomePageResource.ConnectionSettingsFormDescText_Enterprise</p>
}
else
{
<p class="bottom-indent-big">@OneClickHomePageResource.ConnectionSettingsFormDescText_Community</p>
}
<div class="install-step-img bottom-indent"></div>
<div class="bottom-indent-big">
<div class="bottom-indent-big clear-fix">
<div class="install-step semibold">@OneClickHomePageResource.ConnectStepText</div>
<div class="install-step semibold">@OneClickHomePageResource.InstallStepText</div>
<div class="install-step semibold">@OneClickHomePageResource.CustomStepText</div>
<p class="label">@OneClickHomePageResource.CustomStepTitleText</p>
<div class="install-step semibold">@OneClickHomePageResource.UsingStepText</div>
</div>
<div class="bottom-indent-big">
@ -76,7 +82,7 @@
<div class="description display-none">
<h1 class="blue">@OneClickHomePageResource.SetupFormDescHdr</h1>
<p>@OneClickHomePageResource.CommunityServerText</p>
<p>@OneClickHomePageResource.SetupFormDescText</p>
<h2 class="blue">@OneClickHomePageResource.CommunityServerHdr</h2>
<p>@OneClickHomePageResource.CommunityServerText</p>
@ -99,6 +105,12 @@
</ul>
</div>
@if (ViewBag.Enterprise)
{
<h2 class="blue">@OneClickHomePageResource.ControlPanelHdr</h2>
<p>@OneClickHomePageResource.ControlPanelText_Enterprise</p>
}
</div>
<div class="progress display-none">
@ -138,6 +150,14 @@
<div class="progress-desc label"></div>
<div class="progress-icon"></div>
</div>
@if (ViewBag.Enterprise)
{
<div class="progress-row clear-fix" data-step="@((int) InstallationProgressStep.InstallControlPanel)">
<div class="progress-title">@OneClickHomePageResource.InstallationProgressStep_InstallControlPanel</div>
<div class="progress-desc label"></div>
<div class="progress-icon"></div>
</div>
}
<div class="progress-row clear-fix" data-step="@((int)InstallationProgressStep.InstallCommunityServer)">
<div class="progress-title">@OneClickHomePageResource.InstallationProgressStep_InstallCommunityServer</div>
<div class="progress-desc label"></div>
@ -155,48 +175,17 @@
</div>
<div id="settingsFormDesc" class="form-desc display-none">
<h1 class="blue">@OneClickHomePageResource.ServerSettingsFormDescHdr</h1>
<p>@OneClickHomePageResource.ServerSettingsFormDescText_1</p>
<p>@OneClickHomePageResource.ServerSettingsFormDescText_2</p>
<div class="bottom-indent-big">
<a id="enterBtn" class="button green" href="#" target="_blank">
@OneClickCommonResource.Enter
<a id="enterOnlyofficeBtn" class="button green" href="#" target="_blank">
@OneClickCommonResource.EnterOnlyoffice
</a>
</div>
<h2 class="blue clear-fix">
<span class="float-left">@OneClickHomePageResource.ContrrolPanelHdr</span>
<span class="float-left coming-soon"></span>
</h2>
<p>@OneClickHomePageResource.ContrrolPanelText</p>
<table class="bottom-indent" style="width: 100%">
<tr>
<td>
<div class="cp-feature semibold">
<div class="icon https"></div>
@OneClickHomePageResource.ContrrolPanelFeatureHttps
</div>
</td>
<td>
<div class="cp-feature semibold">
<div class="icon audit"></div>
@OneClickHomePageResource.ContrrolPanelFeatureAudit
</div>
</td>
<td>
<div class="cp-feature semibold">
<div class="icon backup"></div>
@OneClickHomePageResource.ContrrolPanelFeatureBackup
</div>
</td>
<td>
<div class="cp-feature semibold">
<div class="icon update"></div>
@OneClickHomePageResource.ContrrolPanelFeatureUpdate
</div>
</td>
</tr>
</table>
</div>

View File

@ -1,7 +1,8 @@

@using OneClickInstallation.Resources
<div class="layout-content-wrapper clear-fix">
<div class="copyright">
@OneClickCommonResource.Copyright
@String.Format(OneClickCommonResource.Copyright, DateTime.Now.Year)
</div>
<div class="social-links clear-fix">

View File

@ -1,4 +1,5 @@

@using OneClickInstallation.Resources
@{
var currentAction = ViewContext.RouteData.Values["action"].ToString().ToLower();
var currentLang = System.Threading.Thread.CurrentThread.CurrentCulture.TwoLetterISOLanguageName;
@ -32,6 +33,12 @@
<a href="@Url.Action("Index")" class="white uppercase selected">
@OneClickHomePageResource.Home
</a>
<a href="@string.Format("http://helpcenter.onlyoffice.com/{0}server/docker/oneclickinstall/faq.aspx", String.Equals(currentLang, "en", StringComparison.OrdinalIgnoreCase) ? "" : currentLang + "/")"
target="_blank" class="white uppercase">
@OneClickHomePageResource.FAQ
</a>
<a href="@string.Format("http://www.onlyoffice.com/{0}/about.aspx", currentLang)" target="_blank" class="white uppercase">
@OneClickCommonResource.About
</a>

View File

@ -26,9 +26,27 @@
<add key="resources.from-db" value="false" />
<add key="analyticsFileUrl" value="" />
<add key="termsFileUrl" value="https://help.onlyoffice.com/products/files/doceditor.aspx?fileid=4404722&amp;doc=L3ZQczhiWDYrTDNsQ0NFNXk5R1RlaWhySEdIcTk1YXI1YXh0dHhtSVd0bz0_IjQ0MDQ3MjIi0" />
<add key="emailSender" value="smtp.email.test|587|sender@email.test|password|true" />
<add key="supportEmail" value="server@onlyoffice.com" />
<add key="sourceUrl" value="https://github.com/ONLYOFFICE/OneClickInstall" />
<add key="devUrl" value="http://dev.onlyoffice.org" />
<add key="helpUrl" value="http://helpcenter.onlyoffice.com/server/docker/community/troubleshooting.aspx#OneclickIssues_block" />
<add key="licenseUrl" value="" />
<add key="docker.community-container-name" value="onlyoffice-community-server" />
<add key="docker.document-container-name" value="onlyoffice-document-server" />
<add key="docker.mail-container-name" value="onlyoffice-mail-server" />
<add key="docker.controlpanel-container-name" value="onlyoffice-control-panel" />
<add key="docker.community-image-name" value="onlyoffice/communityserver" />
<add key="docker.document-image-name" value="onlyoffice/documentserver" />
<add key="docker.mail-image-name" value="onlyoffice/mailserver" />
<add key="docker.controlpanel-image-name" value="onlyoffice/controlpanel" />
<add key="docker.enterprise.community-image-name" value="onlyoffice4enterprise/communityserver-ee" />
<add key="docker.enterprise.document-image-name" value="onlyoffice4enterprise/documentserver-ee" />
<add key="docker.enterprise.mail-image-name" value="onlyoffice/mailserver" />
<add key="docker.enterprise.controlpanel-image-name" value="onlyoffice4enterprise/controlpanel-ee" />
<add key="dockerhub.loginUrl" value="https://hub.docker.com/v2/users/login/" />
<add key="dockerhub.tagsUrlFormat" value="https://hub.docker.com/v2/repositories/{0}/tags/" />
<add key="dockerhub.userName" value="" />
<add key="dockerhub.password" value="" />
<add key="cacheKey" value="clearcache" />
</appSettings>
<system.web>
<customErrors mode="On" defaultRedirect="/">