websitepanel/WebsitePanel/Sources/WebsitePanel.WebPortal/DesktopModules/WebsitePanel/SqlBackupDatabase.ascx.cs

168 lines
No EOL
6.1 KiB
C#

// Copyright (c) 2012, Outercurve Foundation.
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without modification,
// are permitted provided that the following conditions are met:
//
// - Redistributions of source code must retain the above copyright notice, this
// list of conditions and the following disclaimer.
//
// - Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
//
// - Neither the name of the Outercurve Foundation nor the names of its
// contributors may be used to endorse or promote products derived from this
// software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
// ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
// ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
using System;
using System.IO;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using WebsitePanel.Providers.Database;
namespace WebsitePanel.Portal
{
public partial class SqlBackupDatabase : WebsitePanelModuleBase
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
BindDatabase();
}
}
private void BindDatabase()
{
try
{
SqlDatabase database = ES.Services.DatabaseServers.GetSqlDatabase(PanelRequest.ItemID);
litDatabaseName.Text = database.Name;
if (database.GroupName.Contains("MySQL"))
{
txtBackupName.Text = database.Name + ".sql";
}
else
{
txtBackupName.Text = database.Name + ".bak";
}
fileLookup.SelectedFile = "\\";
fileLookup.PackageId = database.PackageId;
BindBackupName();
ToggleControls();
}
catch (Exception ex)
{
ShowErrorMessage("SQL_GET_DATABASE", ex);
return;
}
}
private void BindBackupName()
{
string backupName = Path.GetFileNameWithoutExtension(txtBackupName.Text);
SqlDatabase database = ES.Services.DatabaseServers.GetSqlDatabase(PanelRequest.ItemID);
if (database.GroupName.Contains("MySQL"))
{
txtBackupName.Text = backupName + (chkZipBackup.Checked ? ".zip" : ".sql");
}
else
{
txtBackupName.Text = backupName + (chkZipBackup.Checked ? ".zip" : ".bak");
}
}
private void ToggleControls()
{
fileLookup.Visible = rbCopy.Checked;
}
private void BackupDatabase()
{
try
{
string bakFile = ES.Services.DatabaseServers.BackupSqlDatabase(PanelRequest.ItemID,
txtBackupName.Text, chkZipBackup.Checked, rbDownload.Checked, fileLookup.SelectedFile);
if (rbDownload.Checked && !String.IsNullOrEmpty(bakFile))
{
string fileName = bakFile;
Response.Clear();
Response.AddHeader("Content-Disposition", "attachment; filename=" + Path.GetFileName(fileName));
//Response.AddHeader("Content-Length", files[0].Content.Length.ToString());
Response.ContentType = "application/octet-stream";
int FILE_BUFFER_LENGTH = 5000000;
byte[] buffer = null;
int offset = 0;
do
{
// read remote content
buffer = ES.Services.DatabaseServers.GetSqlBackupBinaryChunk(PanelRequest.ItemID, fileName, offset, FILE_BUFFER_LENGTH);
// write to stream
Response.BinaryWrite(buffer);
offset += FILE_BUFFER_LENGTH;
}
while (buffer.Length == FILE_BUFFER_LENGTH);
Response.End();
}
}
catch (Exception ex)
{
ShowErrorMessage("SQL_BACKUP_DATABASE", ex);
return;
}
RedirectBack();
}
protected void btnBackup_Click(object sender, EventArgs e)
{
BackupDatabase();
}
protected void btnCancel_Click(object sender, EventArgs e)
{
RedirectBack();
}
private void RedirectBack()
{
Response.Redirect(EditUrl("ItemID", PanelRequest.ItemID.ToString(), "edit_item",
PortalUtils.SPACE_ID_PARAM + "=" + PanelSecurity.PackageId));
}
protected void chkZipBackup_CheckedChanged(object sender, EventArgs e)
{
BindBackupName();
}
protected void rbDownload_CheckedChanged(object sender, EventArgs e)
{
ToggleControls();
}
}
}