2023-01-24 15:29:31 +01:00
/ * Copyright ( c ) Cloud Software Group , Inc .
2017-09-13 18:14:07 +02:00
*
2013-06-24 13:41:48 +02:00
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
2017-09-13 18:14:07 +02:00
*
2013-06-24 13:41:48 +02:00
* 1 ) Redistributions of source code must retain the above copyright
* notice , this list of conditions and the following disclaimer .
2017-09-13 18:14:07 +02:00
*
2013-06-24 13:41:48 +02:00
* 2 ) 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 .
2017-09-13 18:14:07 +02:00
*
2013-06-24 13:41:48 +02:00
* 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 .
* /
2013-07-03 12:22:08 +02:00
2013-06-24 13:41:48 +02:00
using System ;
using System.Collections ;
using System.Collections.Generic ;
2017-09-13 18:14:07 +02:00
using System.ComponentModel ;
using System.Globalization ;
2021-04-13 11:05:38 +02:00
using System.Linq ;
2017-09-13 18:14:07 +02:00
using Newtonsoft.Json ;
2013-06-24 13:41:48 +02:00
namespace XenAPI
{
2014-05-16 17:58:13 +02:00
/// <summary>
/// A storage repository
/// First published in XenServer 4.0.
/// </summary>
2013-06-24 13:41:48 +02:00
public partial class SR : XenObject < SR >
{
2019-06-19 10:11:30 +02:00
#region Constructors
2013-06-24 13:41:48 +02:00
public SR ( )
{
}
public SR ( string uuid ,
string name_label ,
string name_description ,
List < storage_operations > allowed_operations ,
Dictionary < string , storage_operations > current_operations ,
List < XenRef < VDI > > VDIs ,
List < XenRef < PBD > > PBDs ,
long virtual_allocation ,
long physical_utilisation ,
long physical_size ,
string type ,
string content_type ,
bool shared ,
Dictionary < string , string > other_config ,
string [ ] tags ,
Dictionary < string , string > sm_config ,
Dictionary < string , XenRef < Blob > > blobs ,
bool local_cache_enabled ,
2016-01-28 22:29:29 +01:00
XenRef < DR_task > introduced_by ,
bool clustered ,
bool is_tools_sr )
2013-06-24 13:41:48 +02:00
{
this . uuid = uuid ;
this . name_label = name_label ;
this . name_description = name_description ;
this . allowed_operations = allowed_operations ;
this . current_operations = current_operations ;
this . VDIs = VDIs ;
this . PBDs = PBDs ;
this . virtual_allocation = virtual_allocation ;
this . physical_utilisation = physical_utilisation ;
this . physical_size = physical_size ;
this . type = type ;
this . content_type = content_type ;
this . shared = shared ;
this . other_config = other_config ;
this . tags = tags ;
this . sm_config = sm_config ;
this . blobs = blobs ;
this . local_cache_enabled = local_cache_enabled ;
this . introduced_by = introduced_by ;
2016-01-28 22:29:29 +01:00
this . clustered = clustered ;
this . is_tools_sr = is_tools_sr ;
2013-06-24 13:41:48 +02:00
}
2019-06-19 10:11:30 +02:00
/// <summary>
/// Creates a new SR from a Hashtable.
/// Note that the fields not contained in the Hashtable
/// will be created with their default values.
/// </summary>
/// <param name="table"></param>
public SR ( Hashtable table )
: this ( )
{
UpdateFrom ( table ) ;
}
2013-06-24 13:41:48 +02:00
/// <summary>
/// Creates a new SR from a Proxy_SR.
/// </summary>
/// <param name="proxy"></param>
public SR ( Proxy_SR proxy )
{
2019-06-19 10:11:30 +02:00
UpdateFrom ( proxy ) ;
2013-06-24 13:41:48 +02:00
}
2019-06-19 10:11:30 +02:00
#endregion
2018-02-16 17:27:30 +01:00
/// <summary>
/// Updates each field of this instance with the value of
/// the corresponding field of a given SR.
/// </summary>
2021-04-13 11:05:38 +02:00
public override void UpdateFrom ( SR record )
{
uuid = record . uuid ;
name_label = record . name_label ;
name_description = record . name_description ;
allowed_operations = record . allowed_operations ;
current_operations = record . current_operations ;
VDIs = record . VDIs ;
PBDs = record . PBDs ;
virtual_allocation = record . virtual_allocation ;
physical_utilisation = record . physical_utilisation ;
physical_size = record . physical_size ;
type = record . type ;
content_type = record . content_type ;
shared = record . shared ;
other_config = record . other_config ;
tags = record . tags ;
sm_config = record . sm_config ;
blobs = record . blobs ;
local_cache_enabled = record . local_cache_enabled ;
introduced_by = record . introduced_by ;
clustered = record . clustered ;
is_tools_sr = record . is_tools_sr ;
2013-06-24 13:41:48 +02:00
}
2019-06-19 10:11:30 +02:00
internal void UpdateFrom ( Proxy_SR proxy )
2013-06-24 13:41:48 +02:00
{
2018-03-22 13:30:43 +01:00
uuid = proxy . uuid = = null ? null : proxy . uuid ;
name_label = proxy . name_label = = null ? null : proxy . name_label ;
name_description = proxy . name_description = = null ? null : proxy . name_description ;
2013-06-24 13:41:48 +02:00
allowed_operations = proxy . allowed_operations = = null ? null : Helper . StringArrayToEnumList < storage_operations > ( proxy . allowed_operations ) ;
current_operations = proxy . current_operations = = null ? null : Maps . convert_from_proxy_string_storage_operations ( proxy . current_operations ) ;
VDIs = proxy . VDIs = = null ? null : XenRef < VDI > . Create ( proxy . VDIs ) ;
PBDs = proxy . PBDs = = null ? null : XenRef < PBD > . Create ( proxy . PBDs ) ;
2018-03-22 13:30:43 +01:00
virtual_allocation = proxy . virtual_allocation = = null ? 0 : long . Parse ( proxy . virtual_allocation ) ;
physical_utilisation = proxy . physical_utilisation = = null ? 0 : long . Parse ( proxy . physical_utilisation ) ;
physical_size = proxy . physical_size = = null ? 0 : long . Parse ( proxy . physical_size ) ;
type = proxy . type = = null ? null : proxy . type ;
content_type = proxy . content_type = = null ? null : proxy . content_type ;
2013-06-24 13:41:48 +02:00
shared = ( bool ) proxy . shared ;
other_config = proxy . other_config = = null ? null : Maps . convert_from_proxy_string_string ( proxy . other_config ) ;
2022-09-12 22:54:02 +02:00
tags = proxy . tags = = null ? new string [ ] { } : ( string [ ] ) proxy . tags ;
2013-06-24 13:41:48 +02:00
sm_config = proxy . sm_config = = null ? null : Maps . convert_from_proxy_string_string ( proxy . sm_config ) ;
blobs = proxy . blobs = = null ? null : Maps . convert_from_proxy_string_XenRefBlob ( proxy . blobs ) ;
local_cache_enabled = ( bool ) proxy . local_cache_enabled ;
introduced_by = proxy . introduced_by = = null ? null : XenRef < DR_task > . Create ( proxy . introduced_by ) ;
2016-01-28 22:29:29 +01:00
clustered = ( bool ) proxy . clustered ;
is_tools_sr = ( bool ) proxy . is_tools_sr ;
2013-06-24 13:41:48 +02:00
}
2018-02-16 17:27:30 +01:00
/// <summary>
/// Given a Hashtable with field-value pairs, it updates the fields of this SR
/// with the values listed in the Hashtable. Note that only the fields contained
/// in the Hashtable will be updated and the rest will remain the same.
2013-06-24 13:41:48 +02:00
/// </summary>
/// <param name="table"></param>
2018-02-16 17:27:30 +01:00
public void UpdateFrom ( Hashtable table )
2013-06-24 13:41:48 +02:00
{
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "uuid" ) )
2018-02-23 17:06:32 +01:00
uuid = Marshalling . ParseString ( table , "uuid" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "name_label" ) )
2018-02-23 17:06:32 +01:00
name_label = Marshalling . ParseString ( table , "name_label" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "name_description" ) )
2018-02-23 17:06:32 +01:00
name_description = Marshalling . ParseString ( table , "name_description" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "allowed_operations" ) )
2018-02-23 17:06:32 +01:00
allowed_operations = Helper . StringArrayToEnumList < storage_operations > ( Marshalling . ParseStringArray ( table , "allowed_operations" ) ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "current_operations" ) )
2018-02-23 17:06:32 +01:00
current_operations = Maps . convert_from_proxy_string_storage_operations ( Marshalling . ParseHashTable ( table , "current_operations" ) ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "VDIs" ) )
2018-02-23 17:06:32 +01:00
VDIs = Marshalling . ParseSetRef < VDI > ( table , "VDIs" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "PBDs" ) )
2018-02-23 17:06:32 +01:00
PBDs = Marshalling . ParseSetRef < PBD > ( table , "PBDs" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "virtual_allocation" ) )
2018-02-23 17:06:32 +01:00
virtual_allocation = Marshalling . ParseLong ( table , "virtual_allocation" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "physical_utilisation" ) )
2018-02-23 17:06:32 +01:00
physical_utilisation = Marshalling . ParseLong ( table , "physical_utilisation" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "physical_size" ) )
2018-02-23 17:06:32 +01:00
physical_size = Marshalling . ParseLong ( table , "physical_size" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "type" ) )
2018-02-23 17:06:32 +01:00
type = Marshalling . ParseString ( table , "type" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "content_type" ) )
2018-02-23 17:06:32 +01:00
content_type = Marshalling . ParseString ( table , "content_type" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "shared" ) )
2018-02-23 17:06:32 +01:00
shared = Marshalling . ParseBool ( table , "shared" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "other_config" ) )
2018-02-23 17:06:32 +01:00
other_config = Maps . convert_from_proxy_string_string ( Marshalling . ParseHashTable ( table , "other_config" ) ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "tags" ) )
2018-02-23 17:06:32 +01:00
tags = Marshalling . ParseStringArray ( table , "tags" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "sm_config" ) )
2018-02-23 17:06:32 +01:00
sm_config = Maps . convert_from_proxy_string_string ( Marshalling . ParseHashTable ( table , "sm_config" ) ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "blobs" ) )
2018-02-23 17:06:32 +01:00
blobs = Maps . convert_from_proxy_string_XenRefBlob ( Marshalling . ParseHashTable ( table , "blobs" ) ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "local_cache_enabled" ) )
2018-02-23 17:06:32 +01:00
local_cache_enabled = Marshalling . ParseBool ( table , "local_cache_enabled" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "introduced_by" ) )
2018-02-23 17:06:32 +01:00
introduced_by = Marshalling . ParseRef < DR_task > ( table , "introduced_by" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "clustered" ) )
2018-02-23 17:06:32 +01:00
clustered = Marshalling . ParseBool ( table , "clustered" ) ;
2018-02-16 17:27:30 +01:00
if ( table . ContainsKey ( "is_tools_sr" ) )
2018-02-23 17:06:32 +01:00
is_tools_sr = Marshalling . ParseBool ( table , "is_tools_sr" ) ;
2013-06-24 13:41:48 +02:00
}
2021-04-13 11:05:38 +02:00
public Proxy_SR ToProxy ( )
{
Proxy_SR result_ = new Proxy_SR ( ) ;
result_ . uuid = uuid ? ? "" ;
result_ . name_label = name_label ? ? "" ;
result_ . name_description = name_description ? ? "" ;
result_ . allowed_operations = allowed_operations = = null ? new string [ ] { } : Helper . ObjectListToStringArray ( allowed_operations ) ;
result_ . current_operations = Maps . convert_to_proxy_string_storage_operations ( current_operations ) ;
result_ . VDIs = VDIs = = null ? new string [ ] { } : Helper . RefListToStringArray ( VDIs ) ;
result_ . PBDs = PBDs = = null ? new string [ ] { } : Helper . RefListToStringArray ( PBDs ) ;
result_ . virtual_allocation = virtual_allocation . ToString ( ) ;
result_ . physical_utilisation = physical_utilisation . ToString ( ) ;
result_ . physical_size = physical_size . ToString ( ) ;
result_ . type = type ? ? "" ;
result_ . content_type = content_type ? ? "" ;
result_ . shared = shared ;
result_ . other_config = Maps . convert_to_proxy_string_string ( other_config ) ;
result_ . tags = tags ;
result_ . sm_config = Maps . convert_to_proxy_string_string ( sm_config ) ;
result_ . blobs = Maps . convert_to_proxy_string_XenRefBlob ( blobs ) ;
result_ . local_cache_enabled = local_cache_enabled ;
result_ . introduced_by = introduced_by ? ? "" ;
result_ . clustered = clustered ;
result_ . is_tools_sr = is_tools_sr ;
return result_ ;
}
2013-06-24 13:41:48 +02:00
public bool DeepEquals ( SR other , bool ignoreCurrentOperations )
{
if ( ReferenceEquals ( null , other ) )
return false ;
if ( ReferenceEquals ( this , other ) )
return true ;
if ( ! ignoreCurrentOperations & & ! Helper . AreEqual2 ( this . current_operations , other . current_operations ) )
return false ;
return Helper . AreEqual2 ( this . _uuid , other . _uuid ) & &
Helper . AreEqual2 ( this . _name_label , other . _name_label ) & &
Helper . AreEqual2 ( this . _name_description , other . _name_description ) & &
Helper . AreEqual2 ( this . _allowed_operations , other . _allowed_operations ) & &
Helper . AreEqual2 ( this . _VDIs , other . _VDIs ) & &
Helper . AreEqual2 ( this . _PBDs , other . _PBDs ) & &
Helper . AreEqual2 ( this . _virtual_allocation , other . _virtual_allocation ) & &
Helper . AreEqual2 ( this . _physical_utilisation , other . _physical_utilisation ) & &
Helper . AreEqual2 ( this . _physical_size , other . _physical_size ) & &
Helper . AreEqual2 ( this . _type , other . _type ) & &
Helper . AreEqual2 ( this . _content_type , other . _content_type ) & &
Helper . AreEqual2 ( this . _shared , other . _shared ) & &
Helper . AreEqual2 ( this . _other_config , other . _other_config ) & &
Helper . AreEqual2 ( this . _tags , other . _tags ) & &
Helper . AreEqual2 ( this . _sm_config , other . _sm_config ) & &
Helper . AreEqual2 ( this . _blobs , other . _blobs ) & &
Helper . AreEqual2 ( this . _local_cache_enabled , other . _local_cache_enabled ) & &
2016-01-28 22:29:29 +01:00
Helper . AreEqual2 ( this . _introduced_by , other . _introduced_by ) & &
Helper . AreEqual2 ( this . _clustered , other . _clustered ) & &
Helper . AreEqual2 ( this . _is_tools_sr , other . _is_tools_sr ) ;
2013-06-24 13:41:48 +02:00
}
public override string SaveChanges ( Session session , string opaqueRef , SR server )
{
if ( opaqueRef = = null )
2018-02-14 12:03:48 +01:00
{
System . Diagnostics . Debug . Assert ( false , "Cannot create instances of this type on the server" ) ;
2013-06-24 13:41:48 +02:00
return "" ;
}
else
{
if ( ! Helper . AreEqual2 ( _other_config , server . _other_config ) )
{
SR . set_other_config ( session , opaqueRef , _other_config ) ;
}
if ( ! Helper . AreEqual2 ( _tags , server . _tags ) )
{
SR . set_tags ( session , opaqueRef , _tags ) ;
}
if ( ! Helper . AreEqual2 ( _sm_config , server . _sm_config ) )
{
SR . set_sm_config ( session , opaqueRef , _sm_config ) ;
}
if ( ! Helper . AreEqual2 ( _name_label , server . _name_label ) )
{
SR . set_name_label ( session , opaqueRef , _name_label ) ;
}
if ( ! Helper . AreEqual2 ( _name_description , server . _name_description ) )
{
SR . set_name_description ( session , opaqueRef , _name_description ) ;
}
if ( ! Helper . AreEqual2 ( _physical_size , server . _physical_size ) )
{
SR . set_physical_size ( session , opaqueRef , _physical_size ) ;
}
return null ;
}
}
2021-04-13 11:05:38 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get a record containing the current state of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static SR get_record ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_record ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return new SR ( session . XmlRpcProxy . sr_get_record ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get a reference to the SR instance with the specified UUID.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_uuid">UUID of object to return</param>
2013-06-24 13:41:48 +02:00
public static XenRef < SR > get_by_uuid ( Session session , string _uuid )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_by_uuid ( session . opaque_ref , _uuid ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < SR > . Create ( session . XmlRpcProxy . sr_get_by_uuid ( session . opaque_ref , _uuid ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get all the SR instances with the given label.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_label">label of object to return</param>
2013-06-24 13:41:48 +02:00
public static List < XenRef < SR > > get_by_name_label ( Session session , string _label )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_by_name_label ( session . opaque_ref , _label ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < SR > . Create ( session . XmlRpcProxy . sr_get_by_name_label ( session . opaque_ref , _label ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the uuid field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static string get_uuid ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_uuid ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return session . XmlRpcProxy . sr_get_uuid ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the name/label field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static string get_name_label ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_name_label ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return session . XmlRpcProxy . sr_get_name_label ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the name/description field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static string get_name_description ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_name_description ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return session . XmlRpcProxy . sr_get_name_description ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the allowed_operations field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static List < storage_operations > get_allowed_operations ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_allowed_operations ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return Helper . StringArrayToEnumList < storage_operations > ( session . XmlRpcProxy . sr_get_allowed_operations ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the current_operations field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static Dictionary < string , storage_operations > get_current_operations ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_current_operations ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return Maps . convert_from_proxy_string_storage_operations ( session . XmlRpcProxy . sr_get_current_operations ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the VDIs field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static List < XenRef < VDI > > get_VDIs ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_vdis ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < VDI > . Create ( session . XmlRpcProxy . sr_get_vdis ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the PBDs field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static List < XenRef < PBD > > get_PBDs ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_pbds ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < PBD > . Create ( session . XmlRpcProxy . sr_get_pbds ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the virtual_allocation field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static long get_virtual_allocation ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_virtual_allocation ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return long . Parse ( session . XmlRpcProxy . sr_get_virtual_allocation ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the physical_utilisation field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static long get_physical_utilisation ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_physical_utilisation ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return long . Parse ( session . XmlRpcProxy . sr_get_physical_utilisation ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the physical_size field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static long get_physical_size ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_physical_size ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return long . Parse ( session . XmlRpcProxy . sr_get_physical_size ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the type field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static string get_type ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_type ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return session . XmlRpcProxy . sr_get_type ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the content_type field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static string get_content_type ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_content_type ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return session . XmlRpcProxy . sr_get_content_type ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the shared field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static bool get_shared ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_shared ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return ( bool ) session . XmlRpcProxy . sr_get_shared ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the other_config field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static Dictionary < string , string > get_other_config ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_other_config ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return Maps . convert_from_proxy_string_string ( session . XmlRpcProxy . sr_get_other_config ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the tags field of the given SR.
/// First published in XenServer 5.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static string [ ] get_tags ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_tags ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2022-09-12 22:54:02 +02:00
return ( string [ ] ) session . XmlRpcProxy . sr_get_tags ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the sm_config field of the given SR.
/// First published in XenServer 4.1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static Dictionary < string , string > get_sm_config ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_sm_config ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return Maps . convert_from_proxy_string_string ( session . XmlRpcProxy . sr_get_sm_config ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the blobs field of the given SR.
/// First published in XenServer 5.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static Dictionary < string , XenRef < Blob > > get_blobs ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_blobs ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return Maps . convert_from_proxy_string_XenRefBlob ( session . XmlRpcProxy . sr_get_blobs ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the local_cache_enabled field of the given SR.
/// First published in XenServer 5.6 FP1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static bool get_local_cache_enabled ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_local_cache_enabled ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return ( bool ) session . XmlRpcProxy . sr_get_local_cache_enabled ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get the introduced_by field of the given SR.
/// First published in XenServer 6.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static XenRef < DR_task > get_introduced_by ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_introduced_by ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < DR_task > . Create ( session . XmlRpcProxy . sr_get_introduced_by ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2016-01-28 22:29:29 +01:00
/// <summary>
/// Get the clustered field of the given SR.
2017-06-28 18:00:22 +02:00
/// First published in XenServer 7.0.
2016-01-28 22:29:29 +01:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
public static bool get_clustered ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_clustered ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return ( bool ) session . XmlRpcProxy . sr_get_clustered ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2016-01-28 22:29:29 +01:00
}
/// <summary>
/// Get the is_tools_sr field of the given SR.
2017-06-28 18:00:22 +02:00
/// First published in XenServer 7.0.
2016-01-28 22:29:29 +01:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
public static bool get_is_tools_sr ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_is_tools_sr ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return ( bool ) session . XmlRpcProxy . sr_get_is_tools_sr ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2016-01-28 22:29:29 +01:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Set the other_config field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_other_config">New value to set</param>
2013-06-24 13:41:48 +02:00
public static void set_other_config ( Session session , string _sr , Dictionary < string , string > _other_config )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_set_other_config ( session . opaque_ref , _sr , _other_config ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_set_other_config ( session . opaque_ref , _sr ? ? "" , Maps . convert_to_proxy_string_string ( _other_config ) ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Add the given key-value pair to the other_config field of the given SR.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_key">Key to add</param>
/// <param name="_value">Value to add</param>
2013-06-24 13:41:48 +02:00
public static void add_to_other_config ( Session session , string _sr , string _key , string _value )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_add_to_other_config ( session . opaque_ref , _sr , _key , _value ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_add_to_other_config ( session . opaque_ref , _sr ? ? "" , _key ? ? "" , _value ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Remove the given key and its corresponding value from the other_config field of the given SR. If the key is not in that Map, then do nothing.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_key">Key to remove</param>
2013-06-24 13:41:48 +02:00
public static void remove_from_other_config ( Session session , string _sr , string _key )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_remove_from_other_config ( session . opaque_ref , _sr , _key ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_remove_from_other_config ( session . opaque_ref , _sr ? ? "" , _key ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Set the tags field of the given SR.
/// First published in XenServer 5.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_tags">New value to set</param>
2013-06-24 13:41:48 +02:00
public static void set_tags ( Session session , string _sr , string [ ] _tags )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_set_tags ( session . opaque_ref , _sr , _tags ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_set_tags ( session . opaque_ref , _sr ? ? "" , _tags ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Add the given value to the tags field of the given SR. If the value is already in that Set, then do nothing.
/// First published in XenServer 5.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_value">New value to add</param>
2013-06-24 13:41:48 +02:00
public static void add_tags ( Session session , string _sr , string _value )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_add_tags ( session . opaque_ref , _sr , _value ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_add_tags ( session . opaque_ref , _sr ? ? "" , _value ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Remove the given value from the tags field of the given SR. If the value is not in that Set, then do nothing.
/// First published in XenServer 5.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_value">Value to remove</param>
2013-06-24 13:41:48 +02:00
public static void remove_tags ( Session session , string _sr , string _value )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_remove_tags ( session . opaque_ref , _sr , _value ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_remove_tags ( session . opaque_ref , _sr ? ? "" , _value ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Set the sm_config field of the given SR.
/// First published in XenServer 4.1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_sm_config">New value to set</param>
2013-06-24 13:41:48 +02:00
public static void set_sm_config ( Session session , string _sr , Dictionary < string , string > _sm_config )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_set_sm_config ( session . opaque_ref , _sr , _sm_config ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_set_sm_config ( session . opaque_ref , _sr ? ? "" , Maps . convert_to_proxy_string_string ( _sm_config ) ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Add the given key-value pair to the sm_config field of the given SR.
/// First published in XenServer 4.1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_key">Key to add</param>
/// <param name="_value">Value to add</param>
2013-06-24 13:41:48 +02:00
public static void add_to_sm_config ( Session session , string _sr , string _key , string _value )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_add_to_sm_config ( session . opaque_ref , _sr , _key , _value ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_add_to_sm_config ( session . opaque_ref , _sr ? ? "" , _key ? ? "" , _value ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Remove the given key and its corresponding value from the sm_config field of the given SR. If the key is not in that Map, then do nothing.
/// First published in XenServer 4.1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_key">Key to remove</param>
2013-06-24 13:41:48 +02:00
public static void remove_from_sm_config ( Session session , string _sr , string _key )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_remove_from_sm_config ( session . opaque_ref , _sr , _key ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_remove_from_sm_config ( session . opaque_ref , _sr ? ? "" , _key ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Create a new Storage Repository and introduce it into the managed system, creating both SR record and PBD record to attach it to current host (with specified device_config parameters)
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_physical_size">The physical size of the new storage repository</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
/// <param name="_shared">True if the SR (is capable of) being shared by multiple hosts</param>
public static XenRef < SR > create ( Session session , string _host , Dictionary < string , string > _device_config , long _physical_size , string _name_label , string _name_description , string _type , string _content_type , bool _shared )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_create ( session . opaque_ref , _host , _device_config , _physical_size , _name_label , _name_description , _type , _content_type , _shared ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < SR > . Create ( session . XmlRpcProxy . sr_create ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _physical_size . ToString ( ) , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" , _shared ) . parse ( ) ) ;
2014-05-16 17:58:13 +02:00
}
/// <summary>
/// Create a new Storage Repository and introduce it into the managed system, creating both SR record and PBD record to attach it to current host (with specified device_config parameters)
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_physical_size">The physical size of the new storage repository</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
/// <param name="_shared">True if the SR (is capable of) being shared by multiple hosts</param>
public static XenRef < Task > async_create ( Session session , string _host , Dictionary < string , string > _device_config , long _physical_size , string _name_label , string _name_description , string _type , string _content_type , bool _shared )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_create ( session . opaque_ref , _host , _device_config , _physical_size , _name_label , _name_description , _type , _content_type , _shared ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_create ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _physical_size . ToString ( ) , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" , _shared ) . parse ( ) ) ;
2014-05-16 17:58:13 +02:00
}
/// <summary>
/// Create a new Storage Repository and introduce it into the managed system, creating both SR record and PBD record to attach it to current host (with specified device_config parameters)
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_physical_size">The physical size of the new storage repository</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
/// <param name="_shared">True if the SR (is capable of) being shared by multiple hosts</param>
/// <param name="_sm_config">Storage backend specific configuration options First published in XenServer 4.1.</param>
2013-06-24 13:41:48 +02:00
public static XenRef < SR > create ( Session session , string _host , Dictionary < string , string > _device_config , long _physical_size , string _name_label , string _name_description , string _type , string _content_type , bool _shared , Dictionary < string , string > _sm_config )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_create ( session . opaque_ref , _host , _device_config , _physical_size , _name_label , _name_description , _type , _content_type , _shared , _sm_config ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < SR > . Create ( session . XmlRpcProxy . sr_create ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _physical_size . ToString ( ) , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" , _shared , Maps . convert_to_proxy_string_string ( _sm_config ) ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Create a new Storage Repository and introduce it into the managed system, creating both SR record and PBD record to attach it to current host (with specified device_config parameters)
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_physical_size">The physical size of the new storage repository</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
/// <param name="_shared">True if the SR (is capable of) being shared by multiple hosts</param>
/// <param name="_sm_config">Storage backend specific configuration options First published in XenServer 4.1.</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_create ( Session session , string _host , Dictionary < string , string > _device_config , long _physical_size , string _name_label , string _name_description , string _type , string _content_type , bool _shared , Dictionary < string , string > _sm_config )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_create ( session . opaque_ref , _host , _device_config , _physical_size , _name_label , _name_description , _type , _content_type , _shared , _sm_config ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_create ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _physical_size . ToString ( ) , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" , _shared , Maps . convert_to_proxy_string_string ( _sm_config ) ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Introduce a new Storage Repository into the managed system
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_uuid">The uuid assigned to the introduced SR</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
/// <param name="_shared">True if the SR (is capable of) being shared by multiple hosts</param>
public static XenRef < SR > introduce ( Session session , string _uuid , string _name_label , string _name_description , string _type , string _content_type , bool _shared )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_introduce ( session . opaque_ref , _uuid , _name_label , _name_description , _type , _content_type , _shared ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < SR > . Create ( session . XmlRpcProxy . sr_introduce ( session . opaque_ref , _uuid ? ? "" , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" , _shared ) . parse ( ) ) ;
2014-05-16 17:58:13 +02:00
}
/// <summary>
/// Introduce a new Storage Repository into the managed system
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_uuid">The uuid assigned to the introduced SR</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
/// <param name="_shared">True if the SR (is capable of) being shared by multiple hosts</param>
public static XenRef < Task > async_introduce ( Session session , string _uuid , string _name_label , string _name_description , string _type , string _content_type , bool _shared )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_introduce ( session . opaque_ref , _uuid , _name_label , _name_description , _type , _content_type , _shared ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_introduce ( session . opaque_ref , _uuid ? ? "" , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" , _shared ) . parse ( ) ) ;
2014-05-16 17:58:13 +02:00
}
/// <summary>
/// Introduce a new Storage Repository into the managed system
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_uuid">The uuid assigned to the introduced SR</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
/// <param name="_shared">True if the SR (is capable of) being shared by multiple hosts</param>
/// <param name="_sm_config">Storage backend specific configuration options First published in XenServer 4.1.</param>
2013-06-24 13:41:48 +02:00
public static XenRef < SR > introduce ( Session session , string _uuid , string _name_label , string _name_description , string _type , string _content_type , bool _shared , Dictionary < string , string > _sm_config )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_introduce ( session . opaque_ref , _uuid , _name_label , _name_description , _type , _content_type , _shared , _sm_config ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < SR > . Create ( session . XmlRpcProxy . sr_introduce ( session . opaque_ref , _uuid ? ? "" , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" , _shared , Maps . convert_to_proxy_string_string ( _sm_config ) ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Introduce a new Storage Repository into the managed system
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_uuid">The uuid assigned to the introduced SR</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
/// <param name="_shared">True if the SR (is capable of) being shared by multiple hosts</param>
/// <param name="_sm_config">Storage backend specific configuration options First published in XenServer 4.1.</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_introduce ( Session session , string _uuid , string _name_label , string _name_description , string _type , string _content_type , bool _shared , Dictionary < string , string > _sm_config )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_introduce ( session . opaque_ref , _uuid , _name_label , _name_description , _type , _content_type , _shared , _sm_config ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_introduce ( session . opaque_ref , _uuid ? ? "" , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" , _shared , Maps . convert_to_proxy_string_string ( _sm_config ) ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Create a new Storage Repository on disk. This call is deprecated: use SR.create instead.
/// First published in XenServer 4.0.
2016-01-28 22:29:29 +01:00
/// Deprecated since XenServer 4.1.
2014-05-16 17:58:13 +02:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_physical_size">The physical size of the new storage repository</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
2016-01-28 22:29:29 +01:00
[Deprecated("XenServer 4.1")]
2014-05-16 17:58:13 +02:00
public static string make ( Session session , string _host , Dictionary < string , string > _device_config , long _physical_size , string _name_label , string _name_description , string _type , string _content_type )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_make ( session . opaque_ref , _host , _device_config , _physical_size , _name_label , _name_description , _type , _content_type ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return session . XmlRpcProxy . sr_make ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _physical_size . ToString ( ) , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" ) . parse ( ) ;
2014-05-16 17:58:13 +02:00
}
/// <summary>
/// Create a new Storage Repository on disk. This call is deprecated: use SR.create instead.
/// First published in XenServer 4.0.
2016-01-28 22:29:29 +01:00
/// Deprecated since XenServer 4.1.
2014-05-16 17:58:13 +02:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_physical_size">The physical size of the new storage repository</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
2016-01-28 22:29:29 +01:00
[Deprecated("XenServer 4.1")]
2014-05-16 17:58:13 +02:00
public static XenRef < Task > async_make ( Session session , string _host , Dictionary < string , string > _device_config , long _physical_size , string _name_label , string _name_description , string _type , string _content_type )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_make ( session . opaque_ref , _host , _device_config , _physical_size , _name_label , _name_description , _type , _content_type ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_make ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _physical_size . ToString ( ) , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" ) . parse ( ) ) ;
2014-05-16 17:58:13 +02:00
}
/// <summary>
/// Create a new Storage Repository on disk. This call is deprecated: use SR.create instead.
/// First published in XenServer 4.0.
2016-01-28 22:29:29 +01:00
/// Deprecated since XenServer 4.1.
2014-05-16 17:58:13 +02:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_physical_size">The physical size of the new storage repository</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
/// <param name="_sm_config">Storage backend specific configuration options First published in XenServer 4.1.</param>
2016-01-28 22:29:29 +01:00
[Deprecated("XenServer 4.1")]
2013-06-24 13:41:48 +02:00
public static string make ( Session session , string _host , Dictionary < string , string > _device_config , long _physical_size , string _name_label , string _name_description , string _type , string _content_type , Dictionary < string , string > _sm_config )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_make ( session . opaque_ref , _host , _device_config , _physical_size , _name_label , _name_description , _type , _content_type , _sm_config ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return session . XmlRpcProxy . sr_make ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _physical_size . ToString ( ) , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" , Maps . convert_to_proxy_string_string ( _sm_config ) ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Create a new Storage Repository on disk. This call is deprecated: use SR.create instead.
/// First published in XenServer 4.0.
2016-01-28 22:29:29 +01:00
/// Deprecated since XenServer 4.1.
2014-05-16 17:58:13 +02:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_physical_size">The physical size of the new storage repository</param>
/// <param name="_name_label">The name of the new storage repository</param>
/// <param name="_name_description">The description of the new storage repository</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_content_type">The type of the new SRs content, if required (e.g. ISOs)</param>
/// <param name="_sm_config">Storage backend specific configuration options First published in XenServer 4.1.</param>
2016-01-28 22:29:29 +01:00
[Deprecated("XenServer 4.1")]
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_make ( Session session , string _host , Dictionary < string , string > _device_config , long _physical_size , string _name_label , string _name_description , string _type , string _content_type , Dictionary < string , string > _sm_config )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_make ( session . opaque_ref , _host , _device_config , _physical_size , _name_label , _name_description , _type , _content_type , _sm_config ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_make ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _physical_size . ToString ( ) , _name_label ? ? "" , _name_description ? ? "" , _type ? ? "" , _content_type ? ? "" , Maps . convert_to_proxy_string_string ( _sm_config ) ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Destroy specified SR, removing SR-record from database and remove SR from disk. (In order to affect this operation the appropriate device_config is read from the specified SR's PBD on current host)
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static void destroy ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_destroy ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_destroy ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Destroy specified SR, removing SR-record from database and remove SR from disk. (In order to affect this operation the appropriate device_config is read from the specified SR's PBD on current host)
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_destroy ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_destroy ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_destroy ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Removing specified SR-record from database, without attempting to remove SR from disk
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static void forget ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_forget ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_forget ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Removing specified SR-record from database, without attempting to remove SR from disk
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_forget ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_forget ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_forget ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Refresh the fields on the SR object
/// First published in XenServer 4.1.1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static void update ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_update ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_update ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Refresh the fields on the SR object
/// First published in XenServer 4.1.1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_update ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_update ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_update ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Return a set of all the SR types supported by the system
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
2013-06-24 13:41:48 +02:00
public static string [ ] get_supported_types ( Session session )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_supported_types ( session . opaque_ref ) ;
2017-09-13 18:14:07 +02:00
else
2022-09-12 22:54:02 +02:00
return ( string [ ] ) session . XmlRpcProxy . sr_get_supported_types ( session . opaque_ref ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Refreshes the list of VDIs associated with an SR
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static void scan ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_scan ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_scan ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Refreshes the list of VDIs associated with an SR
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_scan ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_scan ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_scan ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2022-06-17 15:02:24 +02:00
/// <summary>
/// Perform a backend-specific scan, using the given device_config. If the device_config is complete, then this will return a list of the SRs present of this type on the device, if any. If the device_config is partial, then a backend-specific scan will be performed, returning results that will guide the user in improving the device_config.
/// First published in XenServer 4.1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
public static string probe ( Session session , string _host , Dictionary < string , string > _device_config )
{
if ( session . JsonRpcClient ! = null )
return session . JsonRpcClient . sr_probe ( session . opaque_ref , _host , _device_config ) ;
else
return session . XmlRpcProxy . sr_probe ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) ) . parse ( ) ;
}
/// <summary>
/// Perform a backend-specific scan, using the given device_config. If the device_config is complete, then this will return a list of the SRs present of this type on the device, if any. If the device_config is partial, then a backend-specific scan will be performed, returning results that will guide the user in improving the device_config.
/// First published in XenServer 4.1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
public static XenRef < Task > async_probe ( Session session , string _host , Dictionary < string , string > _device_config )
{
if ( session . JsonRpcClient ! = null )
return session . JsonRpcClient . async_sr_probe ( session . opaque_ref , _host , _device_config ) ;
else
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_probe ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) ) . parse ( ) ) ;
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Perform a backend-specific scan, using the given device_config. If the device_config is complete, then this will return a list of the SRs present of this type on the device, if any. If the device_config is partial, then a backend-specific scan will be performed, returning results that will guide the user in improving the device_config.
/// First published in XenServer 4.1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_sm_config">Storage backend specific configuration options</param>
2013-06-24 13:41:48 +02:00
public static string probe ( Session session , string _host , Dictionary < string , string > _device_config , string _type , Dictionary < string , string > _sm_config )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_probe ( session . opaque_ref , _host , _device_config , _type , _sm_config ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return session . XmlRpcProxy . sr_probe ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _type ? ? "" , Maps . convert_to_proxy_string_string ( _sm_config ) ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Perform a backend-specific scan, using the given device_config. If the device_config is complete, then this will return a list of the SRs present of this type on the device, if any. If the device_config is partial, then a backend-specific scan will be performed, returning results that will guide the user in improving the device_config.
/// First published in XenServer 4.1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_sm_config">Storage backend specific configuration options</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_probe ( Session session , string _host , Dictionary < string , string > _device_config , string _type , Dictionary < string , string > _sm_config )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_probe ( session . opaque_ref , _host , _device_config , _type , _sm_config ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_probe ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _type ? ? "" , Maps . convert_to_proxy_string_string ( _sm_config ) ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2018-03-22 13:30:43 +01:00
/// <summary>
/// Perform a backend-specific scan, using the given device_config. If the device_config is complete, then this will return a list of the SRs present of this type on the device, if any. If the device_config is partial, then a backend-specific scan will be performed, returning results that will guide the user in improving the device_config.
2022-06-17 15:02:24 +02:00
/// First published in XenServer 7.6.
2018-03-22 13:30:43 +01:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_sm_config">Storage backend specific configuration options</param>
public static List < Probe_result > probe_ext ( Session session , string _host , Dictionary < string , string > _device_config , string _type , Dictionary < string , string > _sm_config )
{
if ( session . JsonRpcClient ! = null )
return session . JsonRpcClient . sr_probe_ext ( session . opaque_ref , _host , _device_config , _type , _sm_config ) ;
else
2021-04-13 11:05:38 +02:00
return session . XmlRpcProxy . sr_probe_ext ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _type ? ? "" , Maps . convert_to_proxy_string_string ( _sm_config ) ) . parse ( ) . Select ( p = > new Probe_result ( p ) ) . ToList ( ) ;
2018-03-22 13:30:43 +01:00
}
/// <summary>
/// Perform a backend-specific scan, using the given device_config. If the device_config is complete, then this will return a list of the SRs present of this type on the device, if any. If the device_config is partial, then a backend-specific scan will be performed, returning results that will guide the user in improving the device_config.
2022-06-17 15:02:24 +02:00
/// First published in XenServer 7.6.
2018-03-22 13:30:43 +01:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_host">The host to create/make the SR on</param>
/// <param name="_device_config">The device config string that will be passed to backend SR driver</param>
/// <param name="_type">The type of the SR; used to specify the SR backend driver to use</param>
/// <param name="_sm_config">Storage backend specific configuration options</param>
public static XenRef < Task > async_probe_ext ( Session session , string _host , Dictionary < string , string > _device_config , string _type , Dictionary < string , string > _sm_config )
{
if ( session . JsonRpcClient ! = null )
return session . JsonRpcClient . async_sr_probe_ext ( session . opaque_ref , _host , _device_config , _type , _sm_config ) ;
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_probe_ext ( session . opaque_ref , _host ? ? "" , Maps . convert_to_proxy_string_string ( _device_config ) , _type ? ? "" , Maps . convert_to_proxy_string_string ( _sm_config ) ) . parse ( ) ) ;
2018-03-22 13:30:43 +01:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Sets the shared flag on the SR
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_value">True if the SR is shared</param>
2013-06-24 13:41:48 +02:00
public static void set_shared ( Session session , string _sr , bool _value )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_set_shared ( session . opaque_ref , _sr , _value ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_set_shared ( session . opaque_ref , _sr ? ? "" , _value ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Sets the shared flag on the SR
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_value">True if the SR is shared</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_set_shared ( Session session , string _sr , bool _value )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_set_shared ( session . opaque_ref , _sr , _value ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_set_shared ( session . opaque_ref , _sr ? ? "" , _value ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Set the name label of the SR
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_value">The name label for the SR</param>
2013-06-24 13:41:48 +02:00
public static void set_name_label ( Session session , string _sr , string _value )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_set_name_label ( session . opaque_ref , _sr , _value ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_set_name_label ( session . opaque_ref , _sr ? ? "" , _value ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Set the name label of the SR
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_value">The name label for the SR</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_set_name_label ( Session session , string _sr , string _value )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_set_name_label ( session . opaque_ref , _sr , _value ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_set_name_label ( session . opaque_ref , _sr ? ? "" , _value ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Set the name description of the SR
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_value">The name description for the SR</param>
2013-06-24 13:41:48 +02:00
public static void set_name_description ( Session session , string _sr , string _value )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_set_name_description ( session . opaque_ref , _sr , _value ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_set_name_description ( session . opaque_ref , _sr ? ? "" , _value ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Set the name description of the SR
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_value">The name description for the SR</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_set_name_description ( Session session , string _sr , string _value )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_set_name_description ( session . opaque_ref , _sr , _value ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_set_name_description ( session . opaque_ref , _sr ? ? "" , _value ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Create a placeholder for a named binary blob of data that is associated with this SR
/// First published in XenServer 5.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_name">The name associated with the blob</param>
/// <param name="_mime_type">The mime type for the data. Empty string translates to application/octet-stream</param>
public static XenRef < Blob > create_new_blob ( Session session , string _sr , string _name , string _mime_type )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_create_new_blob ( session . opaque_ref , _sr , _name , _mime_type ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Blob > . Create ( session . XmlRpcProxy . sr_create_new_blob ( session . opaque_ref , _sr ? ? "" , _name ? ? "" , _mime_type ? ? "" ) . parse ( ) ) ;
2014-05-16 17:58:13 +02:00
}
/// <summary>
/// Create a placeholder for a named binary blob of data that is associated with this SR
/// First published in XenServer 5.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_name">The name associated with the blob</param>
/// <param name="_mime_type">The mime type for the data. Empty string translates to application/octet-stream</param>
public static XenRef < Task > async_create_new_blob ( Session session , string _sr , string _name , string _mime_type )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_create_new_blob ( session . opaque_ref , _sr , _name , _mime_type ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_create_new_blob ( session . opaque_ref , _sr ? ? "" , _name ? ? "" , _mime_type ? ? "" ) . parse ( ) ) ;
2014-05-16 17:58:13 +02:00
}
/// <summary>
/// Create a placeholder for a named binary blob of data that is associated with this SR
/// First published in XenServer 5.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_name">The name associated with the blob</param>
/// <param name="_mime_type">The mime type for the data. Empty string translates to application/octet-stream</param>
/// <param name="_public">True if the blob should be publicly available First published in XenServer 6.1.</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Blob > create_new_blob ( Session session , string _sr , string _name , string _mime_type , bool _public )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_create_new_blob ( session . opaque_ref , _sr , _name , _mime_type , _public ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Blob > . Create ( session . XmlRpcProxy . sr_create_new_blob ( session . opaque_ref , _sr ? ? "" , _name ? ? "" , _mime_type ? ? "" , _public ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Create a placeholder for a named binary blob of data that is associated with this SR
/// First published in XenServer 5.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_name">The name associated with the blob</param>
/// <param name="_mime_type">The mime type for the data. Empty string translates to application/octet-stream</param>
/// <param name="_public">True if the blob should be publicly available First published in XenServer 6.1.</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_create_new_blob ( Session session , string _sr , string _name , string _mime_type , bool _public )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_create_new_blob ( session . opaque_ref , _sr , _name , _mime_type , _public ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_create_new_blob ( session . opaque_ref , _sr ? ? "" , _name ? ? "" , _mime_type ? ? "" , _public ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Sets the SR's physical_size field
/// First published in XenServer 4.1.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_value">The new value of the SR's physical_size</param>
public static void set_physical_size ( Session session , string _sr , long _value )
2013-06-24 13:41:48 +02:00
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_set_physical_size ( session . opaque_ref , _sr , _value ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_set_physical_size ( session . opaque_ref , _sr ? ? "" , _value . ToString ( ) ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Returns successfully if the given SR can host an HA statefile. Otherwise returns an error to explain why not
/// First published in XenServer 5.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static void assert_can_host_ha_statefile ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_assert_can_host_ha_statefile ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_assert_can_host_ha_statefile ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Returns successfully if the given SR can host an HA statefile. Otherwise returns an error to explain why not
/// First published in XenServer 5.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_assert_can_host_ha_statefile ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_assert_can_host_ha_statefile ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_assert_can_host_ha_statefile ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Returns successfully if the given SR supports database replication. Otherwise returns an error to explain why not.
/// First published in XenServer 6.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static void assert_supports_database_replication ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_assert_supports_database_replication ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_assert_supports_database_replication ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Returns successfully if the given SR supports database replication. Otherwise returns an error to explain why not.
/// First published in XenServer 6.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_assert_supports_database_replication ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_assert_supports_database_replication ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_assert_supports_database_replication ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
///
/// First published in XenServer 6.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static void enable_database_replication ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_enable_database_replication ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_enable_database_replication ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
///
/// First published in XenServer 6.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_enable_database_replication ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_enable_database_replication ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_enable_database_replication ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
///
/// First published in XenServer 6.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static void disable_database_replication ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_disable_database_replication ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_disable_database_replication ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
///
/// First published in XenServer 6.0.
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
2013-06-24 13:41:48 +02:00
public static XenRef < Task > async_disable_database_replication ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . async_sr_disable_database_replication ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < Task > . Create ( session . XmlRpcProxy . async_sr_disable_database_replication ( session . opaque_ref , _sr ? ? "" ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2016-01-28 22:29:29 +01:00
/// <summary>
///
2017-06-28 18:00:22 +02:00
/// First published in XenServer 7.0.
2016-01-28 22:29:29 +01:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
public static List < Data_source > get_data_sources ( Session session , string _sr )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_data_sources ( session . opaque_ref , _sr ) ;
2017-09-13 18:14:07 +02:00
else
2021-04-13 11:05:38 +02:00
return session . XmlRpcProxy . sr_get_data_sources ( session . opaque_ref , _sr ? ? "" ) . parse ( ) . Select ( p = > new Data_source ( p ) ) . ToList ( ) ;
2016-01-28 22:29:29 +01:00
}
/// <summary>
/// Start recording the specified data source
2017-06-28 18:00:22 +02:00
/// First published in XenServer 7.0.
2016-01-28 22:29:29 +01:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_data_source">The data source to record</param>
public static void record_data_source ( Session session , string _sr , string _data_source )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_record_data_source ( session . opaque_ref , _sr , _data_source ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_record_data_source ( session . opaque_ref , _sr ? ? "" , _data_source ? ? "" ) . parse ( ) ;
2016-01-28 22:29:29 +01:00
}
/// <summary>
/// Query the latest value of the specified data source
2017-06-28 18:00:22 +02:00
/// First published in XenServer 7.0.
2016-01-28 22:29:29 +01:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_data_source">The data source to query</param>
public static double query_data_source ( Session session , string _sr , string _data_source )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_query_data_source ( session . opaque_ref , _sr , _data_source ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return Convert . ToDouble ( session . XmlRpcProxy . sr_query_data_source ( session . opaque_ref , _sr ? ? "" , _data_source ? ? "" ) . parse ( ) ) ;
2016-01-28 22:29:29 +01:00
}
/// <summary>
/// Forget the recorded statistics related to the specified data source
2017-06-28 18:00:22 +02:00
/// First published in XenServer 7.0.
2016-01-28 22:29:29 +01:00
/// </summary>
/// <param name="session">The session</param>
/// <param name="_sr">The opaque_ref of the given sr</param>
/// <param name="_data_source">The data source whose archives are to be forgotten</param>
public static void forget_data_source_archives ( Session session , string _sr , string _data_source )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
session . JsonRpcClient . sr_forget_data_source_archives ( session . opaque_ref , _sr , _data_source ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
session . XmlRpcProxy . sr_forget_data_source_archives ( session . opaque_ref , _sr ? ? "" , _data_source ? ? "" ) . parse ( ) ;
2016-01-28 22:29:29 +01:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Return a list of all the SRs known to the system.
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
2013-06-24 13:41:48 +02:00
public static List < XenRef < SR > > get_all ( Session session )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_all ( session . opaque_ref ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < SR > . Create ( session . XmlRpcProxy . sr_get_all ( session . opaque_ref ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Get all the SR Records at once, in a single XML RPC call
/// First published in XenServer 4.0.
/// </summary>
/// <param name="session">The session</param>
2013-06-24 13:41:48 +02:00
public static Dictionary < XenRef < SR > , SR > get_all_records ( Session session )
{
2017-09-13 18:14:07 +02:00
if ( session . JsonRpcClient ! = null )
2018-02-23 17:06:32 +01:00
return session . JsonRpcClient . sr_get_all_records ( session . opaque_ref ) ;
2017-09-13 18:14:07 +02:00
else
2020-01-30 01:02:24 +01:00
return XenRef < SR > . Create < Proxy_SR > ( session . XmlRpcProxy . sr_get_all_records ( session . opaque_ref ) . parse ( ) ) ;
2013-06-24 13:41:48 +02:00
}
2014-05-16 17:58:13 +02:00
/// <summary>
/// Unique identifier/object reference
/// </summary>
public virtual string uuid
{
get { return _uuid ; }
set
{
if ( ! Helper . AreEqual ( value , _uuid ) )
{
_uuid = value ;
NotifyPropertyChanged ( "uuid" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private string _uuid = "" ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// a human-readable name
/// </summary>
public virtual string name_label
{
get { return _name_label ; }
set
{
if ( ! Helper . AreEqual ( value , _name_label ) )
{
_name_label = value ;
NotifyPropertyChanged ( "name_label" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private string _name_label = "" ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// a notes field containing human-readable description
/// </summary>
public virtual string name_description
{
get { return _name_description ; }
set
{
if ( ! Helper . AreEqual ( value , _name_description ) )
{
_name_description = value ;
NotifyPropertyChanged ( "name_description" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private string _name_description = "" ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// list of the operations allowed in this state. This list is advisory only and the server state may have changed by the time this field is read by a client.
/// </summary>
public virtual List < storage_operations > allowed_operations
{
get { return _allowed_operations ; }
set
{
if ( ! Helper . AreEqual ( value , _allowed_operations ) )
{
_allowed_operations = value ;
NotifyPropertyChanged ( "allowed_operations" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private List < storage_operations > _allowed_operations = new List < storage_operations > ( ) { } ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// links each of the running tasks using this object (by reference) to a current_operation enum which describes the nature of the task.
/// </summary>
public virtual Dictionary < string , storage_operations > current_operations
{
get { return _current_operations ; }
set
{
if ( ! Helper . AreEqual ( value , _current_operations ) )
{
_current_operations = value ;
NotifyPropertyChanged ( "current_operations" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private Dictionary < string , storage_operations > _current_operations = new Dictionary < string , storage_operations > ( ) { } ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// all virtual disks known to this storage repository
/// </summary>
2017-09-13 18:14:07 +02:00
[JsonConverter(typeof(XenRefListConverter<VDI>))]
2014-05-16 17:58:13 +02:00
public virtual List < XenRef < VDI > > VDIs
{
get { return _VDIs ; }
set
{
if ( ! Helper . AreEqual ( value , _VDIs ) )
{
_VDIs = value ;
NotifyPropertyChanged ( "VDIs" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private List < XenRef < VDI > > _VDIs = new List < XenRef < VDI > > ( ) { } ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// describes how particular hosts can see this storage repository
/// </summary>
2017-09-13 18:14:07 +02:00
[JsonConverter(typeof(XenRefListConverter<PBD>))]
2014-05-16 17:58:13 +02:00
public virtual List < XenRef < PBD > > PBDs
{
get { return _PBDs ; }
set
{
if ( ! Helper . AreEqual ( value , _PBDs ) )
{
_PBDs = value ;
NotifyPropertyChanged ( "PBDs" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private List < XenRef < PBD > > _PBDs = new List < XenRef < PBD > > ( ) { } ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// sum of virtual_sizes of all VDIs in this storage repository (in bytes)
/// </summary>
public virtual long virtual_allocation
{
get { return _virtual_allocation ; }
set
{
if ( ! Helper . AreEqual ( value , _virtual_allocation ) )
{
_virtual_allocation = value ;
NotifyPropertyChanged ( "virtual_allocation" ) ;
}
}
}
2013-06-24 13:41:48 +02:00
private long _virtual_allocation ;
2014-05-16 17:58:13 +02:00
/// <summary>
/// physical space currently utilised on this storage repository (in bytes). Note that for sparse disk formats, physical_utilisation may be less than virtual_allocation
/// </summary>
public virtual long physical_utilisation
{
get { return _physical_utilisation ; }
set
{
if ( ! Helper . AreEqual ( value , _physical_utilisation ) )
{
_physical_utilisation = value ;
NotifyPropertyChanged ( "physical_utilisation" ) ;
}
}
}
2013-06-24 13:41:48 +02:00
private long _physical_utilisation ;
2014-05-16 17:58:13 +02:00
/// <summary>
/// total physical size of the repository (in bytes)
/// </summary>
public virtual long physical_size
{
get { return _physical_size ; }
set
{
if ( ! Helper . AreEqual ( value , _physical_size ) )
{
_physical_size = value ;
NotifyPropertyChanged ( "physical_size" ) ;
}
}
}
2013-06-24 13:41:48 +02:00
private long _physical_size ;
2014-05-16 17:58:13 +02:00
/// <summary>
/// type of the storage repository
/// </summary>
public virtual string type
{
get { return _type ; }
set
{
if ( ! Helper . AreEqual ( value , _type ) )
{
_type = value ;
NotifyPropertyChanged ( "type" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private string _type = "" ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// the type of the SR's content, if required (e.g. ISOs)
/// </summary>
public virtual string content_type
{
get { return _content_type ; }
set
{
if ( ! Helper . AreEqual ( value , _content_type ) )
{
_content_type = value ;
NotifyPropertyChanged ( "content_type" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private string _content_type = "" ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// true if this SR is (capable of being) shared between multiple hosts
/// </summary>
public virtual bool shared
{
get { return _shared ; }
set
{
if ( ! Helper . AreEqual ( value , _shared ) )
{
_shared = value ;
NotifyPropertyChanged ( "shared" ) ;
}
}
}
2013-06-24 13:41:48 +02:00
private bool _shared ;
2014-05-16 17:58:13 +02:00
/// <summary>
/// additional configuration
/// </summary>
2018-02-27 15:52:46 +01:00
[JsonConverter(typeof(StringStringMapConverter))]
2014-05-16 17:58:13 +02:00
public virtual Dictionary < string , string > other_config
{
get { return _other_config ; }
set
{
if ( ! Helper . AreEqual ( value , _other_config ) )
{
_other_config = value ;
NotifyPropertyChanged ( "other_config" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private Dictionary < string , string > _other_config = new Dictionary < string , string > ( ) { } ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// user-specified tags for categorization purposes
/// First published in XenServer 5.0.
/// </summary>
public virtual string [ ] tags
{
get { return _tags ; }
set
{
if ( ! Helper . AreEqual ( value , _tags ) )
{
_tags = value ;
NotifyPropertyChanged ( "tags" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private string [ ] _tags = { } ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// SM dependent data
/// First published in XenServer 4.1.
/// </summary>
2018-02-27 15:52:46 +01:00
[JsonConverter(typeof(StringStringMapConverter))]
2014-05-16 17:58:13 +02:00
public virtual Dictionary < string , string > sm_config
{
get { return _sm_config ; }
set
{
if ( ! Helper . AreEqual ( value , _sm_config ) )
{
_sm_config = value ;
NotifyPropertyChanged ( "sm_config" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private Dictionary < string , string > _sm_config = new Dictionary < string , string > ( ) { } ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// Binary blobs associated with this SR
/// First published in XenServer 5.0.
/// </summary>
2017-09-13 18:14:07 +02:00
[JsonConverter(typeof(StringXenRefMapConverter<Blob>))]
2014-05-16 17:58:13 +02:00
public virtual Dictionary < string , XenRef < Blob > > blobs
{
get { return _blobs ; }
set
{
if ( ! Helper . AreEqual ( value , _blobs ) )
{
_blobs = value ;
NotifyPropertyChanged ( "blobs" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private Dictionary < string , XenRef < Blob > > _blobs = new Dictionary < string , XenRef < Blob > > ( ) { } ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// True if this SR is assigned to be the local cache for its host
/// First published in XenServer 5.6 FP1.
/// </summary>
public virtual bool local_cache_enabled
{
get { return _local_cache_enabled ; }
set
{
if ( ! Helper . AreEqual ( value , _local_cache_enabled ) )
{
_local_cache_enabled = value ;
NotifyPropertyChanged ( "local_cache_enabled" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private bool _local_cache_enabled = false ;
2013-06-24 13:41:48 +02:00
2014-05-16 17:58:13 +02:00
/// <summary>
/// The disaster recovery task which introduced this SR
/// First published in XenServer 6.0.
/// </summary>
2017-09-13 18:14:07 +02:00
[JsonConverter(typeof(XenRefConverter<DR_task>))]
2014-05-16 17:58:13 +02:00
public virtual XenRef < DR_task > introduced_by
{
get { return _introduced_by ; }
set
{
if ( ! Helper . AreEqual ( value , _introduced_by ) )
{
_introduced_by = value ;
NotifyPropertyChanged ( "introduced_by" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private XenRef < DR_task > _introduced_by = new XenRef < DR_task > ( "OpaqueRef:NULL" ) ;
2016-01-28 22:29:29 +01:00
/// <summary>
/// True if the SR is using aggregated local storage
2017-06-28 18:00:22 +02:00
/// First published in XenServer 7.0.
2016-01-28 22:29:29 +01:00
/// </summary>
public virtual bool clustered
{
get { return _clustered ; }
set
{
if ( ! Helper . AreEqual ( value , _clustered ) )
{
_clustered = value ;
NotifyPropertyChanged ( "clustered" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private bool _clustered = false ;
2016-01-28 22:29:29 +01:00
/// <summary>
/// True if this is the SR that contains the Tools ISO VDIs
2017-06-28 18:00:22 +02:00
/// First published in XenServer 7.0.
2016-01-28 22:29:29 +01:00
/// </summary>
public virtual bool is_tools_sr
{
get { return _is_tools_sr ; }
set
{
if ( ! Helper . AreEqual ( value , _is_tools_sr ) )
{
_is_tools_sr = value ;
NotifyPropertyChanged ( "is_tools_sr" ) ;
}
}
}
2017-09-13 18:14:07 +02:00
private bool _is_tools_sr = false ;
2013-06-24 13:41:48 +02:00
}
}