101 lines
3.7 KiB
C#
101 lines
3.7 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
|
|
namespace DeploymentHelpers
|
|
{
|
|
/// <summary>
|
|
/// Parameters to control application deployment.
|
|
/// </summary>
|
|
public class DeploymentParameters
|
|
{
|
|
/// <summary>
|
|
/// Creates an instance of <see cref="DeploymentParameters"/>.
|
|
/// </summary>
|
|
/// <param name="applicationPath">Source code location of the target location to be deployed.</param>
|
|
/// <param name="serverType">Where to be deployed on.</param>
|
|
/// <param name="runtimeFlavor">Flavor of the clr to run against.</param>
|
|
/// <param name="runtimeArchitecture">Architecture of the DNX to be used.</param>
|
|
public DeploymentParameters(
|
|
string applicationPath,
|
|
ServerType serverType,
|
|
RuntimeFlavor runtimeFlavor,
|
|
RuntimeArchitecture runtimeArchitecture)
|
|
{
|
|
if (string.IsNullOrEmpty(applicationPath))
|
|
{
|
|
throw new ArgumentException("Value cannot be null.", "applicationPath");
|
|
}
|
|
|
|
if (!Directory.Exists(applicationPath))
|
|
{
|
|
throw new DirectoryNotFoundException(string.Format("Application path {0} does not exist.", applicationPath));
|
|
}
|
|
|
|
ApplicationPath = applicationPath;
|
|
ServerType = serverType;
|
|
RuntimeFlavor = runtimeFlavor;
|
|
RuntimeArchitecture = runtimeArchitecture;
|
|
}
|
|
|
|
public ServerType ServerType { get; private set; }
|
|
|
|
public RuntimeFlavor RuntimeFlavor { get; private set; }
|
|
|
|
public RuntimeArchitecture RuntimeArchitecture { get; private set; }
|
|
|
|
/// <summary>
|
|
/// Suggested base url for the deployed application. The final deployed url could be
|
|
/// different than this. Use <see cref="DeploymentResult.ApplicationBaseUri"/> for the
|
|
/// deployed url.
|
|
/// </summary>
|
|
public string ApplicationBaseUriHint { get; set; }
|
|
|
|
public string EnvironmentName { get; set; }
|
|
|
|
public string ApplicationHostConfigTemplateContent { get; set; }
|
|
|
|
public string ApplicationHostConfigLocation { get; set; }
|
|
|
|
public string SiteName { get; set; }
|
|
|
|
public string ApplicationPath { get; set; }
|
|
|
|
/// <summary>
|
|
/// To publish the application before deployment.
|
|
/// </summary>
|
|
public bool PublishApplicationBeforeDeployment { get; set; }
|
|
|
|
public string PublishedApplicationRootPath { get; set; }
|
|
|
|
/// <summary>
|
|
/// Passes the --no-source option when publishing.
|
|
/// </summary>
|
|
public bool PublishWithNoSource { get; set; }
|
|
|
|
public string DnxRuntime { get; set; }
|
|
|
|
/// <summary>
|
|
/// Environment variables to be set before starting the host.
|
|
/// Not applicable for IIS Scenarios.
|
|
/// </summary>
|
|
public List<KeyValuePair<string, string>> EnvironmentVariables { get; private set; } = new List<KeyValuePair<string, string>>();
|
|
|
|
/// <summary>
|
|
/// For any application level cleanup to be invoked after performing host cleanup.
|
|
/// </summary>
|
|
public Action<DeploymentParameters> UserAdditionalCleanup { get; set; }
|
|
|
|
public override string ToString()
|
|
{
|
|
return string.Format(
|
|
"[Variation] :: ServerType={0}, Runtime={1}, Arch={2}, BaseUrlHint={3}, Publish={4}, NoSource={5}",
|
|
ServerType,
|
|
RuntimeFlavor,
|
|
RuntimeArchitecture,
|
|
ApplicationBaseUriHint,
|
|
PublishApplicationBeforeDeployment,
|
|
PublishWithNoSource);
|
|
}
|
|
}
|
|
} |