/* Copyright (c) Citrix Systems Inc.
* 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.
*
* 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.Collections.Generic;
using System.Xml;
using XenAdmin.Network;
using XenAPI;
using XenAdmin.Core;
namespace XenAdmin.Actions
{
///
/// Used for scanning for CSLG servers
///
public abstract class SrCslgScanAction : PureAsyncAction
{
private readonly string _hostname;
private readonly string _username;
private readonly string _passwordSecret;
///
/// Initializes a new instance of the class.
///
/// The connection.
/// The hostname.
/// The username.
/// The password secret.
protected SrCslgScanAction(IXenConnection connection, string hostname, string username, string passwordSecret)
: base(connection, string.Format(Messages.ACTION_SR_SCAN_NAME_CSLG, hostname), string.Format(Messages.ACTION_SR_SCAN_NAME_CSLG, hostname), true)
{
Util.ThrowIfStringParameterNullOrEmpty(hostname, "hostname");
Util.ThrowIfStringParameterNullOrEmpty(username, "username");
_hostname = hostname;
_username = username;
_passwordSecret = passwordSecret;
}
protected void RunProbe(Dictionary dconf)
{
// CA-40132 create a new secret based on the secret that was passed in to the constructor. This is required so that the
// server doesn't associate the secret with a particular SR and then delete it when the SR is detached.
string newPasswordSecret = Secret.CreateSecret(Session, _passwordSecret);
dconf["password_secret"] = newPasswordSecret;
try
{
RelatedTask = XenAPI.SR.async_probe(Session, Helpers.GetMaster(Connection).opaque_ref, dconf, XenAPI.SR.SRTypes.cslg.ToString(), new Dictionary());
PollToCompletion();
}
finally
{
// now destroy the secret.
if (!string.IsNullOrEmpty(newPasswordSecret))
{
string newSecretRef = Secret.get_by_uuid(Session, newPasswordSecret);
Secret.destroy(Session, newSecretRef);
}
}
}
protected Dictionary GetAuthenticationDeviceConfig()
{
Dictionary dconf = new Dictionary();
dconf.Add("target", _hostname);
dconf.Add("username", _username);
dconf.Add("password_secret", _passwordSecret);
return dconf;
}
protected string GetXmlNodeInnerText(XmlNode node, string xPath)
{
Util.ThrowIfParameterNull(node, "node");
Util.ThrowIfStringParameterNullOrEmpty(xPath, "xPath");
XmlNodeList nodes = node.SelectNodes(xPath);
if (nodes == null || nodes.Count == 0)
{
throw new InvalidOperationException("Node not found: " + xPath);
}
return nodes[0].InnerText;
}
protected List GetXmlChildNodeInnerTexts(XmlNode node, string xPath)
{
Util.ThrowIfParameterNull(node, "node");
Util.ThrowIfStringParameterNullOrEmpty(xPath, "xPath");
List output = new List();
XmlNodeList nodes = node.SelectNodes(xPath);
if (nodes == null)
{
throw new InvalidOperationException("Node not found: " + xPath);
}
foreach (XmlNode n in nodes)
{
output.Add(n.InnerText);
}
return output;
}
}
}