diff --git a/README.md b/README.md index 1641978..cc5e372 100644 --- a/README.md +++ b/README.md @@ -1,5 +1,5 @@ # samples -Примеры использования Lers Framework +Примеры использования Lers Framework и веб-службы Проекты: @@ -7,3 +7,4 @@ AttributesSample Работа с атрибутами. Консольное пр GetDataSample Получение данных из ЛЭРС УЧЁТ. Консольное приложение. ImportTemperature Импорт температуры наружного воздуха в ЛЭРС УЧЁТ. KhvAdmDataAdapter Экспорт данных из ЛЭРС УЧЁТ. Обработчик HttpHandler для веб-сайта +WebApiSamples Примеры использования веб-службы ЛЭРС УЧЁТ diff --git a/WebApiSamples/Asp.net+JavaScript/TestLersApi.sln b/WebApiSamples/Asp.net+JavaScript/TestLersApi.sln new file mode 100644 index 0000000..4694192 --- /dev/null +++ b/WebApiSamples/Asp.net+JavaScript/TestLersApi.sln @@ -0,0 +1,22 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio 14 +VisualStudioVersion = 14.0.24720.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "TestLersApi", "TestLersApi\TestLersApi.csproj", "{10B68319-F7E8-4460-9BF8-B7C0D6FFB9BB}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {10B68319-F7E8-4460-9BF8-B7C0D6FFB9BB}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {10B68319-F7E8-4460-9BF8-B7C0D6FFB9BB}.Debug|Any CPU.Build.0 = Debug|Any CPU + {10B68319-F7E8-4460-9BF8-B7C0D6FFB9BB}.Release|Any CPU.ActiveCfg = Release|Any CPU + {10B68319-F7E8-4460-9BF8-B7C0D6FFB9BB}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/WebApiSamples/Asp.net+JavaScript/TestLersApi/Default.aspx b/WebApiSamples/Asp.net+JavaScript/TestLersApi/Default.aspx new file mode 100644 index 0000000..704b8ce --- /dev/null +++ b/WebApiSamples/Asp.net+JavaScript/TestLersApi/Default.aspx @@ -0,0 +1,17 @@ +<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="TestLersApi.Default" %> + + + + + + + + +
+
+ + +
+
+ + diff --git a/WebApiSamples/Asp.net+JavaScript/TestLersApi/Default.aspx.cs b/WebApiSamples/Asp.net+JavaScript/TestLersApi/Default.aspx.cs new file mode 100644 index 0000000..8809930 --- /dev/null +++ b/WebApiSamples/Asp.net+JavaScript/TestLersApi/Default.aspx.cs @@ -0,0 +1,17 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Web; +using System.Web.UI; +using System.Web.UI.WebControls; + +namespace TestLersApi +{ + public partial class Default : System.Web.UI.Page + { + protected void Page_Load(object sender, EventArgs e) + { + + } + } +} \ No newline at end of file diff --git a/WebApiSamples/Asp.net+JavaScript/TestLersApi/Default.aspx.designer.cs b/WebApiSamples/Asp.net+JavaScript/TestLersApi/Default.aspx.designer.cs new file mode 100644 index 0000000..12c2b33 --- /dev/null +++ b/WebApiSamples/Asp.net+JavaScript/TestLersApi/Default.aspx.designer.cs @@ -0,0 +1,23 @@ +//------------------------------------------------------------------------------ +// <автоматически создаваемое> +// Этот код создан программой. +// +// Изменения в этом файле могут привести к неправильной работе и будут потеряны в случае +// повторной генерации кода. +// +//------------------------------------------------------------------------------ + +namespace TestLersApi +{ + public partial class Default { + + /// + /// form1 элемент управления. + /// + /// + /// Автоматически создаваемое поле. + /// Для изменения переместите объявление поля из файла конструктора в файл кода программной части. + /// + protected global::System.Web.UI.HtmlControls.HtmlForm form1; + } +} diff --git a/WebApiSamples/Asp.net+JavaScript/TestLersApi/Properties/AssemblyInfo.cs b/WebApiSamples/Asp.net+JavaScript/TestLersApi/Properties/AssemblyInfo.cs new file mode 100644 index 0000000..1807097 --- /dev/null +++ b/WebApiSamples/Asp.net+JavaScript/TestLersApi/Properties/AssemblyInfo.cs @@ -0,0 +1,35 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// Управление общими сведениями о сборке осуществляется с помощью +// набора атрибутов. Измените значения этих атрибутов для изменения сведений, +// общие сведения об этой сборке. +[assembly: AssemblyTitle("TestLersApi")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("TestLersApi")] +[assembly: AssemblyCopyright("Copyright © 2012")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// Установка значения False в параметре ComVisible делает типы в этой сборке невидимыми +// для COM-компонентов. Если необходим доступ к типу в этой сборке из +// COM, следует установить атрибут ComVisible в TRUE для этого типа. +[assembly: ComVisible(false)] + +// Указанный ниже идентификатор GUID предназначен для идентификации библиотеки типов, если этот проект будет видимым для COM-объектов +[assembly: Guid("245ef887-0d90-4ff8-a52c-5399e292cdfb")] + +// Сведения о версии сборки состоят из указанных ниже четырех значений: +// +// Основной номер версии +// Дополнительный номер версии +// Номер сборки +// Редакция +// +// Можно задать все значения или принять номер построения и номер редакции по умолчанию, +// используя "*", как показано ниже: +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/WebApiSamples/Asp.net+JavaScript/TestLersApi/TestLersApi.csproj b/WebApiSamples/Asp.net+JavaScript/TestLersApi/TestLersApi.csproj new file mode 100644 index 0000000..2566972 --- /dev/null +++ b/WebApiSamples/Asp.net+JavaScript/TestLersApi/TestLersApi.csproj @@ -0,0 +1,108 @@ + + + + + Debug + AnyCPU + + + 2.0 + {10B68319-F7E8-4460-9BF8-B7C0D6FFB9BB} + {349c5851-65df-11da-9384-00065b846f21};{fae04ec0-301f-11d3-bf4b-00c04f79efbc} + Library + Properties + TestLersApi + TestLersApi + v4.0 + false + + + + + 4.0 + + + true + full + false + bin\ + DEBUG;TRACE + prompt + 4 + + + pdbonly + true + bin\ + TRACE + prompt + 4 + + + + + + + + + + + + + + + + + + + + + + + + + + + + Default.aspx + ASPXCodeBehind + + + Default.aspx + + + + + 10.0 + $(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion) + + + + + + + + + False + True + 58035 + / + + + False + False + + + False + + + + + + \ No newline at end of file diff --git a/WebApiSamples/Asp.net+JavaScript/TestLersApi/TestLersApi.js b/WebApiSamples/Asp.net+JavaScript/TestLersApi/TestLersApi.js new file mode 100644 index 0000000..0d703ad --- /dev/null +++ b/WebApiSamples/Asp.net+JavaScript/TestLersApi/TestLersApi.js @@ -0,0 +1,160 @@ +/// + +$(document).ready(function () { + + // Разрешаем кроссдоменное взаимодействие (cross-domain, XCC - Cross-site scripting) по технологии CORS (Cross-origin resource sharing) + jQuery.support.cors = true; + + // Отправляем запрос на вход в систему + SendLoginRequest('demo', 'demo'); +}); + + +function ReceivedLoginResponse(data) { +/// +/// Обработчик события успешного входа в систему +/// + + // Данные получаемые от сервера содержатся в свойстве d + data = data.d; + + // Если есть ошибка, выводим её, иначе отправляем запрос на получение списка точек учета + + if (data.IsError) + alert(data.ErrorMessage); + else + SendGetMeasurePointListRequest(); +} + +function ReceivedMeasurePointListResponse(data) { +/// +/// Обработчик события получения списка точек учета +/// + + // Данные получаемые от сервера содержатся в свойстве d + data = data.d; + + // Если список точек учета не пустой отправляем запрос на получение потребления по первой точке учета из списка + if (data.MeasurePointList.length > 0) + SendGetMeasurePointConsumptionRequest(data.MeasurePointList[0].Id); +} + +function ReceivedMeasurePointConsumptionResponse(data) { +/// +/// Обработчик события получение потребления по точке учета +/// + + // Данные получаемые от сервера содержатся в свойстве d + data = data.d; + + // Если есть данные потребления, выводим сообщение со значением T_in за первую метку времени + if (data.Data.length > 0) + { + var jsonDate = data.Data[0].DateTime + + var dataDate = new Date(parseInt(jsonDate.substr(6))); + var T_in = data.Data[0].T_in; + + alert(dataDate.toString() + ': ' + T_in.toString()); + } + else + alert('По точке учета нет данных потребления.'); + + // Получаем список объектов учета с расширенной информацией + SendGetNodeListExtendedRequest(); +} + +function ReceivedNodeListExtendedResponse(data) +/// +/// Обработчик события получение списка объектов учета +/// +{ + // Данные получаемые от сервера содержатся в свойстве d + data = data.d; +} + +function SendLoginRequest(userName, password) { +/// +/// Отправляет запрос на вход в систему ЛЭРС УЧЕТ +/// + + $.ajax({ + type: "POST", + url: "http://localhost:54025/Api.asmx/Login", + contentType: "application/json; charset=utf-8", + dataType: "json", + xhrFields: { withCredentials: true }, + crossDomain: true, + data: "{ 'userName':'" + userName + "','password':'" + password + "' }", + success: ReceivedLoginResponse, + error: function (jqXHR, textStatus, errorThrown) { + alert('Не удалось войти в систему.'); + } + }); +} + +function SendGetMeasurePointListRequest() { +/// +/// Отправляет запрос на получение списка точек учета +/// + + $.ajax({ + type: "POST", + url: "http://localhost:54025/Api.asmx/GetMeasurePointList", + contentType: "application/json; charset=utf-8", + dataType: "json", + xhrFields: { withCredentials: true }, + crossDomain: true, + data: "", + success: ReceivedMeasurePointListResponse, + error: function (jqXHR, textStatus, errorThrown) { + alert('Не удалось получить список точек учета.'); + } + }); +} + +function SendGetNodeListExtendedRequest() { + /// + /// Отправляет запрос на получение списка объектов учета + /// + + $.ajax({ + type: "POST", + url: "http://localhost:54025/Api.asmx/GetNodeListExtended", + contentType: "application/json; charset=utf-8", + dataType: "json", + xhrFields: { withCredentials: true }, + crossDomain: true, + data: "{ 'flags':" + 1024 + "}", // Запрашиваем помещения + success: ReceivedNodeListExtendedResponse, + error: function (jqXHR, textStatus, errorThrown) { + alert('Не удалось получить список объектов учета.'); + } + }); +} + +function SendGetMeasurePointConsumptionRequest(measurePointId) { + /// + /// Отправляет запрос на получение потребления за текущий месяц + /// + + var nowDate = new Date(); + + var currentStartDate = new Date(nowDate.getFullYear(), nowDate.getMonth(), 1); + var currentEndDate = new Date(nowDate.getFullYear(), nowDate.getMonth(), nowDate.getDate()); + + $.ajax({ + type: "POST", + url: "http://localhost:54025/Api.asmx/GetMeasurePointConsumption", + contentType: "application/json; charset=utf-8", + dataType: "json", + xhrFields: { withCredentials: true }, + crossDomain: true, + data: "{ 'measurePointId':" + measurePointId + ", 'startDate':'" + currentStartDate.toJSON() + "','endDate':'" + currentEndDate.toJSON() + "', 'dataType': 'Day' }", + success: ReceivedMeasurePointConsumptionResponse, + error: function (jqXHR, textStatus, errorThrown) { + alert('Не удалось получить данные потребления по точке учета.'); + } + }); +} + diff --git a/WebApiSamples/Asp.net+JavaScript/TestLersApi/Web.config b/WebApiSamples/Asp.net+JavaScript/TestLersApi/Web.config new file mode 100644 index 0000000..0c362bd --- /dev/null +++ b/WebApiSamples/Asp.net+JavaScript/TestLersApi/Web.config @@ -0,0 +1,13 @@ + + + + + + + + + + diff --git a/WebApiSamples/Asp.net+JavaScript/TestLersApi/jquery-1.6.4.min.js b/WebApiSamples/Asp.net+JavaScript/TestLersApi/jquery-1.6.4.min.js new file mode 100644 index 0000000..628ed9b --- /dev/null +++ b/WebApiSamples/Asp.net+JavaScript/TestLersApi/jquery-1.6.4.min.js @@ -0,0 +1,4 @@ +/*! jQuery v1.6.4 http://jquery.com/ | http://jquery.org/license */ +(function(a,b){function cu(a){return f.isWindow(a)?a:a.nodeType===9?a.defaultView||a.parentWindow:!1}function cr(a){if(!cg[a]){var b=c.body,d=f("<"+a+">").appendTo(b),e=d.css("display");d.remove();if(e==="none"||e===""){ch||(ch=c.createElement("iframe"),ch.frameBorder=ch.width=ch.height=0),b.appendChild(ch);if(!ci||!ch.createElement)ci=(ch.contentWindow||ch.contentDocument).document,ci.write((c.compatMode==="CSS1Compat"?"":"")+""),ci.close();d=ci.createElement(a),ci.body.appendChild(d),e=f.css(d,"display"),b.removeChild(ch)}cg[a]=e}return cg[a]}function cq(a,b){var c={};f.each(cm.concat.apply([],cm.slice(0,b)),function(){c[this]=a});return c}function cp(){cn=b}function co(){setTimeout(cp,0);return cn=f.now()}function cf(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}function ce(){try{return new a.XMLHttpRequest}catch(b){}}function b$(a,c){a.dataFilter&&(c=a.dataFilter(c,a.dataType));var d=a.dataTypes,e={},g,h,i=d.length,j,k=d[0],l,m,n,o,p;for(g=1;g0){c!=="border"&&f.each(e,function(){c||(d-=parseFloat(f.css(a,"padding"+this))||0),c==="margin"?d+=parseFloat(f.css(a,c+this))||0:d-=parseFloat(f.css(a,"border"+this+"Width"))||0});return d+"px"}d=bv(a,b,b);if(d<0||d==null)d=a.style[b]||0;d=parseFloat(d)||0,c&&f.each(e,function(){d+=parseFloat(f.css(a,"padding"+this))||0,c!=="padding"&&(d+=parseFloat(f.css(a,"border"+this+"Width"))||0),c==="margin"&&(d+=parseFloat(f.css(a,c+this))||0)});return d+"px"}function bl(a,b){b.src?f.ajax({url:b.src,async:!1,dataType:"script"}):f.globalEval((b.text||b.textContent||b.innerHTML||"").replace(bd,"/*$0*/")),b.parentNode&&b.parentNode.removeChild(b)}function bk(a){f.nodeName(a,"input")?bj(a):"getElementsByTagName"in a&&f.grep(a.getElementsByTagName("input"),bj)}function bj(a){if(a.type==="checkbox"||a.type==="radio")a.defaultChecked=a.checked}function bi(a){return"getElementsByTagName"in a?a.getElementsByTagName("*"):"querySelectorAll"in a?a.querySelectorAll("*"):[]}function bh(a,b){var c;if(b.nodeType===1){b.clearAttributes&&b.clearAttributes(),b.mergeAttributes&&b.mergeAttributes(a),c=b.nodeName.toLowerCase();if(c==="object")b.outerHTML=a.outerHTML;else if(c!=="input"||a.type!=="checkbox"&&a.type!=="radio"){if(c==="option")b.selected=a.defaultSelected;else if(c==="input"||c==="textarea")b.defaultValue=a.defaultValue}else a.checked&&(b.defaultChecked=b.checked=a.checked),b.value!==a.value&&(b.value=a.value);b.removeAttribute(f.expando)}}function bg(a,b){if(b.nodeType===1&&!!f.hasData(a)){var c=f.expando,d=f.data(a),e=f.data(b,d);if(d=d[c]){var g=d.events;e=e[c]=f.extend({},d);if(g){delete e.handle,e.events={};for(var h in g)for(var i=0,j=g[h].length;i=0===c})}function U(a){return!a||!a.parentNode||a.parentNode.nodeType===11}function M(a,b){return(a&&a!=="*"?a+".":"")+b.replace(y,"`").replace(z,"&")}function L(a){var b,c,d,e,g,h,i,j,k,l,m,n,o,p=[],q=[],r=f._data(this,"events");if(!(a.liveFired===this||!r||!r.live||a.target.disabled||a.button&&a.type==="click")){a.namespace&&(n=new RegExp("(^|\\.)"+a.namespace.split(".").join("\\.(?:.*\\.)?")+"(\\.|$)")),a.liveFired=this;var s=r.live.slice(0);for(i=0;ic)break;a.currentTarget=e.elem,a.data=e.handleObj.data,a.handleObj=e.handleObj,o=e.handleObj.origHandler.apply(e.elem,arguments);if(o===!1||a.isPropagationStopped()){c=e.level,o===!1&&(b=!1);if(a.isImmediatePropagationStopped())break}}return b}}function J(a,c,d){var e=f.extend({},d[0]);e.type=a,e.originalEvent={},e.liveFired=b,f.event.handle.call(c,e),e.isDefaultPrevented()&&d[0].preventDefault()}function D(){return!0}function C(){return!1}function m(a,c,d){var e=c+"defer",g=c+"queue",h=c+"mark",i=f.data(a,e,b,!0);i&&(d==="queue"||!f.data(a,g,b,!0))&&(d==="mark"||!f.data(a,h,b,!0))&&setTimeout(function(){!f.data(a,g,b,!0)&&!f.data(a,h,b,!0)&&(f.removeData(a,e,!0),i.resolve())},0)}function l(a){for(var b in a)if(b!=="toJSON")return!1;return!0}function k(a,c,d){if(d===b&&a.nodeType===1){var e="data-"+c.replace(j,"-$1").toLowerCase();d=a.getAttribute(e);if(typeof d=="string"){try{d=d==="true"?!0:d==="false"?!1:d==="null"?null:f.isNaN(d)?i.test(d)?f.parseJSON(d):d:parseFloat(d)}catch(g){}f.data(a,c,d)}else d=b}return d}var c=a.document,d=a.navigator,e=a.location,f=function(){function K(){if(!e.isReady){try{c.documentElement.doScroll("left")}catch(a){setTimeout(K,1);return}e.ready()}}var e=function(a,b){return new e.fn.init(a,b,h)},f=a.jQuery,g=a.$,h,i=/^(?:[^#<]*(<[\w\W]+>)[^>]*$|#([\w\-]*)$)/,j=/\S/,k=/^\s+/,l=/\s+$/,m=/\d/,n=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,o=/^[\],:{}\s]*$/,p=/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,q=/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,r=/(?:^|:|,)(?:\s*\[)+/g,s=/(webkit)[ \/]([\w.]+)/,t=/(opera)(?:.*version)?[ \/]([\w.]+)/,u=/(msie) ([\w.]+)/,v=/(mozilla)(?:.*? rv:([\w.]+))?/,w=/-([a-z]|[0-9])/ig,x=/^-ms-/,y=function(a,b){return(b+"").toUpperCase()},z=d.userAgent,A,B,C,D=Object.prototype.toString,E=Object.prototype.hasOwnProperty,F=Array.prototype.push,G=Array.prototype.slice,H=String.prototype.trim,I=Array.prototype.indexOf,J={};e.fn=e.prototype={constructor:e,init:function(a,d,f){var g,h,j,k;if(!a)return this;if(a.nodeType){this.context=this[0]=a,this.length=1;return this}if(a==="body"&&!d&&c.body){this.context=c,this[0]=c.body,this.selector=a,this.length=1;return this}if(typeof a=="string"){a.charAt(0)!=="<"||a.charAt(a.length-1)!==">"||a.length<3?g=i.exec(a):g=[null,a,null];if(g&&(g[1]||!d)){if(g[1]){d=d instanceof e?d[0]:d,k=d?d.ownerDocument||d:c,j=n.exec(a),j?e.isPlainObject(d)?(a=[c.createElement(j[1])],e.fn.attr.call(a,d,!0)):a=[k.createElement(j[1])]:(j=e.buildFragment([g[1]],[k]),a=(j.cacheable?e.clone(j.fragment):j.fragment).childNodes);return e.merge(this,a)}h=c.getElementById(g[2]);if(h&&h.parentNode){if(h.id!==g[2])return f.find(a);this.length=1,this[0]=h}this.context=c,this.selector=a;return this}return!d||d.jquery?(d||f).find(a):this.constructor(d).find(a)}if(e.isFunction(a))return f.ready(a);a.selector!==b&&(this.selector=a.selector,this.context=a.context);return e.makeArray(a,this)},selector:"",jquery:"1.6.4",length:0,size:function(){return this.length},toArray:function(){return G.call(this,0)},get:function(a){return a==null?this.toArray():a<0?this[this.length+a]:this[a]},pushStack:function(a,b,c){var d=this.constructor();e.isArray(a)?F.apply(d,a):e.merge(d,a),d.prevObject=this,d.context=this.context,b==="find"?d.selector=this.selector+(this.selector?" ":"")+c:b&&(d.selector=this.selector+"."+b+"("+c+")");return d},each:function(a,b){return e.each(this,a,b)},ready:function(a){e.bindReady(),B.done(a);return this},eq:function(a){return a===-1?this.slice(a):this.slice(a,+a+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(G.apply(this,arguments),"slice",G.call(arguments).join(","))},map:function(a){return this.pushStack(e.map(this,function(b,c){return a.call(b,c,b)}))},end:function(){return this.prevObject||this.constructor(null)},push:F,sort:[].sort,splice:[].splice},e.fn.init.prototype=e.fn,e.extend=e.fn.extend=function(){var a,c,d,f,g,h,i=arguments[0]||{},j=1,k=arguments.length,l=!1;typeof i=="boolean"&&(l=i,i=arguments[1]||{},j=2),typeof i!="object"&&!e.isFunction(i)&&(i={}),k===j&&(i=this,--j);for(;j0)return;B.resolveWith(c,[e]),e.fn.trigger&&e(c).trigger("ready").unbind("ready")}},bindReady:function(){if(!B){B=e._Deferred();if(c.readyState==="complete")return setTimeout(e.ready,1);if(c.addEventListener)c.addEventListener("DOMContentLoaded",C,!1),a.addEventListener("load",e.ready,!1);else if(c.attachEvent){c.attachEvent("onreadystatechange",C),a.attachEvent("onload",e.ready);var b=!1;try{b=a.frameElement==null}catch(d){}c.documentElement.doScroll&&b&&K()}}},isFunction:function(a){return e.type(a)==="function"},isArray:Array.isArray||function(a){return e.type(a)==="array"},isWindow:function(a){return a&&typeof a=="object"&&"setInterval"in a},isNaN:function(a){return a==null||!m.test(a)||isNaN(a)},type:function(a){return a==null?String(a):J[D.call(a)]||"object"},isPlainObject:function(a){if(!a||e.type(a)!=="object"||a.nodeType||e.isWindow(a))return!1;try{if(a.constructor&&!E.call(a,"constructor")&&!E.call(a.constructor.prototype,"isPrototypeOf"))return!1}catch(c){return!1}var d;for(d in a);return d===b||E.call(a,d)},isEmptyObject:function(a){for(var b in a)return!1;return!0},error:function(a){throw a},parseJSON:function(b){if(typeof b!="string"||!b)return null;b=e.trim(b);if(a.JSON&&a.JSON.parse)return a.JSON.parse(b);if(o.test(b.replace(p,"@").replace(q,"]").replace(r,"")))return(new Function("return "+b))();e.error("Invalid JSON: "+b)},parseXML:function(c){var d,f;try{a.DOMParser?(f=new DOMParser,d=f.parseFromString(c,"text/xml")):(d=new ActiveXObject("Microsoft.XMLDOM"),d.async="false",d.loadXML(c))}catch(g){d=b}(!d||!d.documentElement||d.getElementsByTagName("parsererror").length)&&e.error("Invalid XML: "+c);return d},noop:function(){},globalEval:function(b){b&&j.test(b)&&(a.execScript||function(b){a.eval.call(a,b)})(b)},camelCase:function(a){return a.replace(x,"ms-").replace(w,y)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toUpperCase()===b.toUpperCase()},each:function(a,c,d){var f,g=0,h=a.length,i=h===b||e.isFunction(a);if(d){if(i){for(f in a)if(c.apply(a[f],d)===!1)break}else for(;g0&&a[0]&&a[j-1]||j===0||e.isArray(a));if(k)for(;i1?h.call(arguments,0):c,--e||g.resolveWith(g,h.call(b,0))}}var b=arguments,c=0,d=b.length,e=d,g=d<=1&&a&&f.isFunction(a.promise)?a:f.Deferred();if(d>1){for(;c
a",d=a.getElementsByTagName("*"),e=a.getElementsByTagName("a")[0];if(!d||!d.length||!e)return{};g=c.createElement("select"),h=g.appendChild(c.createElement("option")),i=a.getElementsByTagName("input")[0],k={leadingWhitespace:a.firstChild.nodeType===3,tbody:!a.getElementsByTagName("tbody").length,htmlSerialize:!!a.getElementsByTagName("link").length,style:/top/.test(e.getAttribute("style")),hrefNormalized:e.getAttribute("href")==="/a",opacity:/^0.55$/.test(e.style.opacity),cssFloat:!!e.style.cssFloat,checkOn:i.value==="on",optSelected:h.selected,getSetAttribute:a.className!=="t",submitBubbles:!0,changeBubbles:!0,focusinBubbles:!1,deleteExpando:!0,noCloneEvent:!0,inlineBlockNeedsLayout:!1,shrinkWrapBlocks:!1,reliableMarginRight:!0},i.checked=!0,k.noCloneChecked=i.cloneNode(!0).checked,g.disabled=!0,k.optDisabled=!h.disabled;try{delete a.test}catch(v){k.deleteExpando=!1}!a.addEventListener&&a.attachEvent&&a.fireEvent&&(a.attachEvent("onclick",function(){k.noCloneEvent=!1}),a.cloneNode(!0).fireEvent("onclick")),i=c.createElement("input"),i.value="t",i.setAttribute("type","radio"),k.radioValue=i.value==="t",i.setAttribute("checked","checked"),a.appendChild(i),l=c.createDocumentFragment(),l.appendChild(a.firstChild),k.checkClone=l.cloneNode(!0).cloneNode(!0).lastChild.checked,a.innerHTML="",a.style.width=a.style.paddingLeft="1px",m=c.getElementsByTagName("body")[0],o=c.createElement(m?"div":"body"),p={visibility:"hidden",width:0,height:0,border:0,margin:0,background:"none"},m&&f.extend(p,{position:"absolute",left:"-1000px",top:"-1000px"});for(t in p)o.style[t]=p[t];o.appendChild(a),n=m||b,n.insertBefore(o,n.firstChild),k.appendChecked=i.checked,k.boxModel=a.offsetWidth===2,"zoom"in a.style&&(a.style.display="inline",a.style.zoom=1,k.inlineBlockNeedsLayout=a.offsetWidth===2,a.style.display="",a.innerHTML="
",k.shrinkWrapBlocks=a.offsetWidth!==2),a.innerHTML="
t
",q=a.getElementsByTagName("td"),u=q[0].offsetHeight===0,q[0].style.display="",q[1].style.display="none",k.reliableHiddenOffsets=u&&q[0].offsetHeight===0,a.innerHTML="",c.defaultView&&c.defaultView.getComputedStyle&&(j=c.createElement("div"),j.style.width="0",j.style.marginRight="0",a.appendChild(j),k.reliableMarginRight=(parseInt((c.defaultView.getComputedStyle(j,null)||{marginRight:0}).marginRight,10)||0)===0),o.innerHTML="",n.removeChild(o);if(a.attachEvent)for(t in{submit:1,change:1,focusin:1})s="on"+t,u=s in a,u||(a.setAttribute(s,"return;"),u=typeof a[s]=="function"),k[t+"Bubbles"]=u;o=l=g=h=m=j=a=i=null;return k}(),f.boxModel=f.support.boxModel;var i=/^(?:\{.*\}|\[.*\])$/,j=/([A-Z])/g;f.extend({cache:{},uuid:0,expando:"jQuery"+(f.fn.jquery+Math.random()).replace(/\D/g,""),noData:{embed:!0,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",applet:!0},hasData:function(a){a=a.nodeType?f.cache[a[f.expando]]:a[f.expando];return!!a&&!l(a)},data:function(a,c,d,e){if(!!f.acceptData(a)){var g,h,i=f.expando,j=typeof c=="string",k=a.nodeType,l=k?f.cache:a,m=k?a[f.expando]:a[f.expando]&&f.expando;if((!m||e&&m&&l[m]&&!l[m][i])&&j&&d===b)return;m||(k?a[f.expando]=m=++f.uuid:m=f.expando),l[m]||(l[m]={},k||(l[m].toJSON=f.noop));if(typeof c=="object"||typeof c=="function")e?l[m][i]=f.extend(l[m][i],c):l[m]=f.extend(l[m],c);g=l[m],e&&(g[i]||(g[i]={}),g=g[i]),d!==b&&(g[f.camelCase(c)]=d);if(c==="events"&&!g[c])return g[i]&&g[i].events;j?(h=g[c],h==null&&(h=g[f.camelCase(c)])):h=g;return h}},removeData:function(a,b,c){if(!!f.acceptData(a)){var d,e=f.expando,g=a.nodeType,h=g?f.cache:a,i=g?a[f.expando]:f.expando;if(!h[i])return;if(b){d=c?h[i][e]:h[i];if(d){d[b]||(b=f.camelCase(b)),delete d[b];if(!l(d))return}}if(c){delete h[i][e];if(!l(h[i]))return}var j=h[i][e];f.support.deleteExpando||!h.setInterval?delete h[i]:h[i]=null,j?(h[i]={},g||(h[i].toJSON=f.noop),h[i][e]=j):g&&(f.support.deleteExpando?delete a[f.expando]:a.removeAttribute?a.removeAttribute(f.expando):a[f.expando]=null)}},_data:function(a,b,c){return f.data(a,b,c,!0)},acceptData:function(a){if(a.nodeName){var b=f.noData[a.nodeName.toLowerCase()];if(b)return b!==!0&&a.getAttribute("classid")===b}return!0}}),f.fn.extend({data:function(a,c){var d=null;if(typeof a=="undefined"){if(this.length){d=f.data(this[0]);if(this[0].nodeType===1){var e=this[0].attributes,g;for(var h=0,i=e.length;h-1)return!0;return!1},val:function(a){var c,d,e=this[0];if(!arguments.length){if(e){c=f.valHooks[e.nodeName.toLowerCase()]||f.valHooks[e.type];if(c&&"get"in c&&(d=c.get(e,"value"))!==b)return d;d=e.value;return typeof d=="string"?d.replace(p,""):d==null?"":d}return b}var g=f.isFunction(a);return this.each(function(d){var e=f(this),h;if(this.nodeType===1){g?h=a.call(this,d,e.val()):h=a,h==null?h="":typeof h=="number"?h+="":f.isArray(h)&&(h=f.map(h,function(a){return a==null?"":a+""})),c=f.valHooks[this.nodeName.toLowerCase()]||f.valHooks[this.type];if(!c||!("set"in c)||c.set(this,h,"value")===b)this.value=h}})}}),f.extend({valHooks:{option:{get:function(a){var b=a.attributes.value;return!b||b.specified?a.value:a.text}},select:{get:function(a){var b,c=a.selectedIndex,d=[],e=a.options,g=a.type==="select-one";if(c<0)return null;for(var h=g?c:0,i=g?c+1:e.length;h=0}),c.length||(a.selectedIndex=-1);return c}}},attrFn:{val:!0,css:!0,html:!0,text:!0,data:!0,width:!0,height:!0,offset:!0},attrFix:{tabindex:"tabIndex"},attr:function(a,c,d,e){var g=a.nodeType;if(!a||g===3||g===8||g===2)return b;if(e&&c in f.attrFn)return f(a)[c](d);if(!("getAttribute"in a))return f.prop(a,c,d);var h,i,j=g!==1||!f.isXMLDoc(a);j&&(c=f.attrFix[c]||c,i=f.attrHooks[c],i||(t.test(c)?i=v:u&&(i=u)));if(d!==b){if(d===null){f.removeAttr(a,c);return b}if(i&&"set"in i&&j&&(h=i.set(a,d,c))!==b)return h;a.setAttribute(c,""+d);return d}if(i&&"get"in i&&j&&(h=i.get(a,c))!==null)return h;h=a.getAttribute(c);return h===null?b:h},removeAttr:function(a,b){var c;a.nodeType===1&&(b=f.attrFix[b]||b,f.attr(a,b,""),a.removeAttribute(b),t.test(b)&&(c=f.propFix[b]||b)in a&&(a[c]=!1))},attrHooks:{type:{set:function(a,b){if(q.test(a.nodeName)&&a.parentNode)f.error("type property can't be changed");else if(!f.support.radioValue&&b==="radio"&&f.nodeName(a,"input")){var c=a.value;a.setAttribute("type",b),c&&(a.value=c);return b}}},value:{get:function(a,b){if(u&&f.nodeName(a,"button"))return u.get(a,b);return b in a?a.value:null},set:function(a,b,c){if(u&&f.nodeName(a,"button"))return u.set(a,b,c);a.value=b}}},propFix:{tabindex:"tabIndex",readonly:"readOnly","for":"htmlFor","class":"className",maxlength:"maxLength",cellspacing:"cellSpacing",cellpadding:"cellPadding",rowspan:"rowSpan",colspan:"colSpan",usemap:"useMap",frameborder:"frameBorder",contenteditable:"contentEditable"},prop:function(a,c,d){var e=a.nodeType;if(!a||e===3||e===8||e===2)return b;var g,h,i=e!==1||!f.isXMLDoc(a);i&&(c=f.propFix[c]||c,h=f.propHooks[c]);return d!==b?h&&"set"in h&&(g=h.set(a,d,c))!==b?g:a[c]=d:h&&"get"in h&&(g=h.get(a,c))!==null?g:a[c]},propHooks:{tabIndex:{get:function(a){var c=a.getAttributeNode("tabindex");return c&&c.specified?parseInt(c.value,10):r.test(a.nodeName)||s.test(a.nodeName)&&a.href?0:b}}}}),f.attrHooks.tabIndex=f.propHooks.tabIndex,v={get:function(a,c){var d;return f.prop(a,c)===!0||(d=a.getAttributeNode(c))&&d.nodeValue!==!1?c.toLowerCase():b},set:function(a,b,c){var d;b===!1?f.removeAttr(a,c):(d=f.propFix[c]||c,d in a&&(a[d]=!0),a.setAttribute(c,c.toLowerCase()));return c}},f.support.getSetAttribute||(u=f.valHooks.button={get:function(a,c){var d;d=a.getAttributeNode(c);return d&&d.nodeValue!==""?d.nodeValue:b},set:function(a,b,d){var e=a.getAttributeNode(d);e||(e=c.createAttribute(d),a.setAttributeNode(e));return e.nodeValue=b+""}},f.each(["width","height"],function(a,b){f.attrHooks[b]=f.extend(f.attrHooks[b],{set:function(a,c){if(c===""){a.setAttribute(b,"auto");return c}}})})),f.support.hrefNormalized||f.each(["href","src","width","height"],function(a,c){f.attrHooks[c]=f.extend(f.attrHooks[c],{get:function(a){var d=a.getAttribute(c,2);return d===null?b:d}})}),f.support.style||(f.attrHooks.style={get:function(a){return a.style.cssText.toLowerCase()||b},set:function(a,b){return a.style.cssText=""+b}}),f.support.optSelected||(f.propHooks.selected=f.extend(f.propHooks.selected,{get:function(a){var b=a.parentNode;b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex);return null}})),f.support.checkOn||f.each(["radio","checkbox"],function(){f.valHooks[this]={get:function(a){return a.getAttribute("value")===null?"on":a.value}}}),f.each(["radio","checkbox"],function(){f.valHooks[this]=f.extend(f.valHooks[this],{set:function(a,b){if(f.isArray(b))return a.checked=f.inArray(f(a).val(),b)>=0}})});var w=/\.(.*)$/,x=/^(?:textarea|input|select)$/i,y=/\./g,z=/ /g,A=/[^\w\s.|`]/g,B=function(a){return a.replace(A,"\\$&")};f.event={add:function(a,c,d,e){if(a.nodeType!==3&&a.nodeType!==8){if(d===!1)d=C;else if(!d)return;var g,h;d.handler&&(g=d,d=g.handler),d.guid||(d.guid=f.guid++);var i=f._data(a);if(!i)return;var j=i.events,k=i.handle;j||(i.events=j={}),k||(i.handle=k=function(a){return typeof f!="undefined"&&(!a||f.event.triggered!==a.type)?f.event.handle.apply(k.elem,arguments):b}),k.elem=a,c=c.split(" ");var l,m=0,n;while(l=c[m++]){h=g?f.extend({},g):{handler:d,data:e},l.indexOf(".")>-1?(n=l.split("."),l=n.shift(),h.namespace=n.slice(0).sort().join(".")):(n=[],h.namespace=""),h.type=l,h.guid||(h.guid=d.guid);var o=j[l],p=f.event.special[l]||{};if(!o){o=j[l]=[];if(!p.setup||p.setup.call(a,e,n,k)===!1)a.addEventListener?a.addEventListener(l,k,!1):a.attachEvent&&a.attachEvent("on"+l,k)}p.add&&(p.add.call(a,h),h.handler.guid||(h.handler.guid=d.guid)),o.push(h),f.event.global[l]=!0}a=null}},global:{},remove:function(a,c,d,e){if(a.nodeType!==3&&a.nodeType!==8){d===!1&&(d=C);var g,h,i,j,k=0,l,m,n,o,p,q,r,s=f.hasData(a)&&f._data(a),t=s&&s.events;if(!s||!t)return;c&&c.type&&(d=c.handler,c=c.type);if(!c||typeof c=="string"&&c.charAt(0)==="."){c=c||"";for(h in t)f.event.remove(a,h+c);return}c=c.split(" ");while(h=c[k++]){r=h,q=null,l=h.indexOf(".")<0,m=[],l||(m=h.split("."),h=m.shift(),n=new RegExp("(^|\\.)"+f.map(m.slice(0).sort(),B).join("\\.(?:.*\\.)?")+"(\\.|$)")),p=t[h];if(!p)continue;if(!d){for(j=0;j=0&&(h=h.slice(0,-1),j=!0),h.indexOf(".")>=0&&(i=h.split("."),h=i.shift(),i.sort());if(!!e&&!f.event.customEvent[h]||!!f.event.global[h]){c=typeof c=="object"?c[f.expando]?c:new f.Event(h,c):new f.Event(h),c.type=h,c.exclusive=j,c.namespace=i.join("."),c.namespace_re=new RegExp("(^|\\.)"+i.join("\\.(?:.*\\.)?")+"(\\.|$)");if(g||!e)c.preventDefault(),c.stopPropagation();if(!e){f.each(f.cache,function(){var a=f.expando,b=this[a];b&&b.events&&b.events[h]&&f.event.trigger(c,d,b.handle.elem)});return}if(e.nodeType===3||e.nodeType===8)return;c.result=b,c.target=e,d=d!=null?f.makeArray(d):[],d.unshift(c);var k=e,l=h.indexOf(":")<0?"on"+h:"";do{var m=f._data(k,"handle");c.currentTarget=k,m&&m.apply(k,d),l&&f.acceptData(k)&&k[l]&&k[l].apply(k,d)===!1&&(c.result=!1,c.preventDefault()),k=k.parentNode||k.ownerDocument||k===c.target.ownerDocument&&a}while(k&&!c.isPropagationStopped());if(!c.isDefaultPrevented()){var n,o=f.event.special[h]||{};if((!o._default||o._default.call(e.ownerDocument,c)===!1)&&(h!=="click"||!f.nodeName(e,"a"))&&f.acceptData(e)){try{l&&e[h]&&(n=e[l],n&&(e[l]=null),f.event.triggered=h,e[h]())}catch(p){}n&&(e[l]=n),f.event.triggered=b}}return c.result}},handle:function(c){c=f.event.fix(c||a.event);var d=((f._data(this,"events")||{})[c.type]||[]).slice(0),e=!c.exclusive&&!c.namespace,g=Array.prototype.slice.call(arguments,0);g[0]=c,c.currentTarget=this;for(var h=0,i=d.length;h-1?f.map(a.options,function(a){return a.selected}).join("-"):"":f.nodeName(a,"select")&&(c=a.selectedIndex);return c},I=function(c){var d=c.target,e,g;if(!!x.test(d.nodeName)&&!d.readOnly){e=f._data(d,"_change_data"),g=H(d),(c.type!=="focusout"||d.type!=="radio")&&f._data(d,"_change_data",g);if(e===b||g===e)return;if(e!=null||g)c.type="change",c.liveFired=b,f.event.trigger(c,arguments[1],d)}};f.event.special.change={filters:{focusout:I,beforedeactivate:I,click:function(a){var b=a.target,c=f.nodeName(b,"input")?b.type:"";(c==="radio"||c==="checkbox"||f.nodeName(b,"select"))&&I.call(this,a)},keydown:function(a){var b=a.target,c=f.nodeName(b,"input")?b.type:"";(a.keyCode===13&&!f.nodeName(b,"textarea")||a.keyCode===32&&(c==="checkbox"||c==="radio")||c==="select-multiple")&&I.call(this,a)},beforeactivate:function(a){var b=a.target;f._data(b,"_change_data",H(b))}},setup:function(a,b){if(this.type==="file")return!1;for(var c in G)f.event.add(this,c+".specialChange",G[c]);return x.test(this.nodeName)},teardown:function(a){f.event.remove(this,".specialChange");return x.test(this.nodeName)}},G=f.event.special.change.filters,G.focus=G.beforeactivate}f.support.focusinBubbles||f.each({focus:"focusin",blur:"focusout"},function(a,b){function e(a){var c=f.event.fix(a);c.type=b,c.originalEvent={},f.event.trigger(c,null,c.target),c.isDefaultPrevented()&&a.preventDefault()}var d=0;f.event.special[b]={setup:function(){d++===0&&c.addEventListener(a,e,!0)},teardown:function(){--d===0&&c.removeEventListener(a,e,!0)}}}),f.each(["bind","one"],function(a,c){f.fn[c]=function(a,d,e){var g;if(typeof a=="object"){for(var h in a)this[c](h,d,a[h],e);return this}if(arguments.length===2||d===!1)e=d,d=b;c==="one"?(g=function(a){f(this).unbind(a,g);return e.apply(this,arguments)},g.guid=e.guid||f.guid++):g=e;if(a==="unload"&&c!=="one")this.one(a,d,e);else for(var i=0,j=this.length;i0?this.bind(b,a,c):this.trigger(b)},f.attrFn&&(f.attrFn[b]=!0)}),function(){function u(a,b,c,d,e,f){for(var g=0,h=d.length;g0){j=i;break}}i=i[a]}d[g]=j}}}function t(a,b,c,d,e,f){for(var g=0,h=d.length;g+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,d=0,e=Object.prototype.toString,g=!1,h=!0,i=/\\/g,j=/\W/;[0,0].sort(function(){h=!1;return 0});var k=function(b,d,f,g){f=f||[],d=d||c;var h=d;if(d.nodeType!==1&&d.nodeType!==9)return[];if(!b||typeof b!="string")return f;var i,j,n,o,q,r,s,t,u=!0,w=k.isXML(d),x=[],y=b;do{a.exec(""),i=a.exec(y);if(i){y=i[3],x.push(i[1]);if(i[2]){o=i[3];break}}}while(i);if(x.length>1&&m.exec(b))if(x.length===2&&l.relative[x[0]])j=v(x[0]+x[1],d);else{j=l.relative[x[0]]?[d]:k(x.shift(),d);while(x.length)b=x.shift(),l.relative[b]&&(b+=x.shift()),j=v(b,j)}else{!g&&x.length>1&&d.nodeType===9&&!w&&l.match.ID.test(x[0])&&!l.match.ID.test(x[x.length-1])&&(q=k.find(x.shift(),d,w),d=q.expr?k.filter(q.expr,q.set)[0]:q.set[0]);if(d){q=g?{expr:x.pop(),set:p(g)}:k.find(x.pop(),x.length===1&&(x[0]==="~"||x[0]==="+")&&d.parentNode?d.parentNode:d,w),j=q.expr?k.filter(q.expr,q.set):q.set,x.length>0?n=p(j):u=!1;while(x.length)r=x.pop(),s=r,l.relative[r]?s=x.pop():r="",s==null&&(s=d),l.relative[r](n,s,w)}else n=x=[]}n||(n=j),n||k.error(r||b);if(e.call(n)==="[object Array]")if(!u)f.push.apply(f,n);else if(d&&d.nodeType===1)for(t=0;n[t]!=null;t++)n[t]&&(n[t]===!0||n[t].nodeType===1&&k.contains(d,n[t]))&&f.push(j[t]);else for(t=0;n[t]!=null;t++)n[t]&&n[t].nodeType===1&&f.push(j[t]);else p(n,f);o&&(k(o,h,f,g),k.uniqueSort(f));return f};k.uniqueSort=function(a){if(r){g=h,a.sort(r);if(g)for(var b=1;b0},k.find=function(a,b,c){var d;if(!a)return[];for(var e=0,f=l.order.length;e":function(a,b){var c,d=typeof b=="string",e=0,f=a.length;if(d&&!j.test(b)){b=b.toLowerCase();for(;e=0)?c||d.push(h):c&&(b[g]=!1));return!1},ID:function(a){return a[1].replace(i,"")},TAG:function(a,b){return a[1].replace(i,"").toLowerCase()},CHILD:function(a){if(a[1]==="nth"){a[2]||k.error(a[0]),a[2]=a[2].replace(/^\+|\s*/g,"");var b=/(-?)(\d*)(?:n([+\-]?\d*))?/.exec(a[2]==="even"&&"2n"||a[2]==="odd"&&"2n+1"||!/\D/.test(a[2])&&"0n+"+a[2]||a[2]);a[2]=b[1]+(b[2]||1)-0,a[3]=b[3]-0}else a[2]&&k.error(a[0]);a[0]=d++;return a},ATTR:function(a,b,c,d,e,f){var g=a[1]=a[1].replace(i,"");!f&&l.attrMap[g]&&(a[1]=l.attrMap[g]),a[4]=(a[4]||a[5]||"").replace(i,""),a[2]==="~="&&(a[4]=" "+a[4]+" ");return a},PSEUDO:function(b,c,d,e,f){if(b[1]==="not")if((a.exec(b[3])||"").length>1||/^\w/.test(b[3]))b[3]=k(b[3],null,null,c);else{var g=k.filter(b[3],c,d,!0^f);d||e.push.apply(e,g);return!1}else if(l.match.POS.test(b[0])||l.match.CHILD.test(b[0]))return!0;return b},POS:function(a){a.unshift(!0);return a}},filters:{enabled:function(a){return a.disabled===!1&&a.type!=="hidden"},disabled:function(a){return a.disabled===!0},checked:function(a){return a.checked===!0},selected:function(a){a.parentNode&&a.parentNode.selectedIndex;return a.selected===!0},parent:function(a){return!!a.firstChild},empty:function(a){return!a.firstChild},has:function(a,b,c){return!!k(c[3],a).length},header:function(a){return/h\d/i.test(a.nodeName)},text:function(a){var b=a.getAttribute("type"),c=a.type;return a.nodeName.toLowerCase()==="input"&&"text"===c&&(b===c||b===null)},radio:function(a){return a.nodeName.toLowerCase()==="input"&&"radio"===a.type},checkbox:function(a){return a.nodeName.toLowerCase()==="input"&&"checkbox"===a.type},file:function(a){return a.nodeName.toLowerCase()==="input"&&"file"===a.type},password:function(a){return a.nodeName.toLowerCase()==="input"&&"password"===a.type},submit:function(a){var b=a.nodeName.toLowerCase();return(b==="input"||b==="button")&&"submit"===a.type},image:function(a){return a.nodeName.toLowerCase()==="input"&&"image"===a.type},reset:function(a){var b=a.nodeName.toLowerCase();return(b==="input"||b==="button")&&"reset"===a.type},button:function(a){var b=a.nodeName.toLowerCase();return b==="input"&&"button"===a.type||b==="button"},input:function(a){return/input|select|textarea|button/i.test(a.nodeName)},focus:function(a){return a===a.ownerDocument.activeElement}},setFilters:{first:function(a,b){return b===0},last:function(a,b,c,d){return b===d.length-1},even:function(a,b){return b%2===0},odd:function(a,b){return b%2===1},lt:function(a,b,c){return bc[3]-0},nth:function(a,b,c){return c[3]-0===b},eq:function(a,b,c){return c[3]-0===b}},filter:{PSEUDO:function(a,b,c,d){var e=b[1],f=l.filters[e];if(f)return f(a,c,b,d);if(e==="contains")return(a.textContent||a.innerText||k.getText([a])||"").indexOf(b[3])>=0;if(e==="not"){var g=b[3];for(var h=0,i=g.length;h=0}},ID:function(a,b){return a.nodeType===1&&a.getAttribute("id")===b},TAG:function(a,b){return b==="*"&&a.nodeType===1||a.nodeName.toLowerCase()===b},CLASS:function(a,b){return(" "+(a.className||a.getAttribute("class"))+" ").indexOf(b)>-1},ATTR:function(a,b){var c=b[1],d=l.attrHandle[c]?l.attrHandle[c](a):a[c]!=null?a[c]:a.getAttribute(c),e=d+"",f=b[2],g=b[4];return d==null?f==="!=":f==="="?e===g:f==="*="?e.indexOf(g)>=0:f==="~="?(" "+e+" ").indexOf(g)>=0:g?f==="!="?e!==g:f==="^="?e.indexOf(g)===0:f==="$="?e.substr(e.length-g.length)===g:f==="|="?e===g||e.substr(0,g.length+1)===g+"-":!1:e&&d!==!1},POS:function(a,b,c,d){var e=b[2],f=l.setFilters[e];if(f)return f(a,c,b,d)}}},m=l.match.POS,n=function(a,b){return"\\"+(b-0+1)};for(var o in l.match)l.match[o]=new RegExp(l.match[o].source+/(?![^\[]*\])(?![^\(]*\))/.source),l.leftMatch[o]=new RegExp(/(^(?:.|\r|\n)*?)/.source+l.match[o].source.replace(/\\(\d+)/g,n));var p=function(a,b){a=Array.prototype.slice.call(a,0);if(b){b.push.apply(b,a);return b}return a};try{Array.prototype.slice.call(c.documentElement.childNodes,0)[0].nodeType}catch(q){p=function(a,b){var c=0,d=b||[];if(e.call(a)==="[object Array]")Array.prototype.push.apply(d,a);else if(typeof a.length=="number")for(var f=a.length;c",e.insertBefore(a,e.firstChild),c.getElementById(d)&&(l.find.ID=function(a,c,d){if(typeof c.getElementById!="undefined"&&!d){var e=c.getElementById(a[1]);return e?e.id===a[1]||typeof e.getAttributeNode!="undefined"&&e.getAttributeNode("id").nodeValue===a[1]?[e]:b:[]}},l.filter.ID=function(a,b){var c=typeof a.getAttributeNode!="undefined"&&a.getAttributeNode("id");return a.nodeType===1&&c&&c.nodeValue===b}),e.removeChild(a),e=a=null}(),function(){var a=c.createElement("div");a.appendChild(c.createComment("")),a.getElementsByTagName("*").length>0&&(l.find.TAG=function(a,b){var c=b.getElementsByTagName(a[1]);if(a[1]==="*"){var d=[];for(var e=0;c[e];e++)c[e].nodeType===1&&d.push(c[e]);c=d}return c}),a.innerHTML="",a.firstChild&&typeof a.firstChild.getAttribute!="undefined"&&a.firstChild.getAttribute("href")!=="#"&&(l.attrHandle.href=function(a){return a.getAttribute("href",2)}),a=null}(),c.querySelectorAll&&function(){var a=k,b=c.createElement("div"),d="__sizzle__";b.innerHTML="

";if(!b.querySelectorAll||b.querySelectorAll(".TEST").length!==0){k=function(b,e,f,g){e=e||c;if(!g&&!k.isXML(e)){var h=/^(\w+$)|^\.([\w\-]+$)|^#([\w\-]+$)/.exec(b);if(h&&(e.nodeType===1||e.nodeType===9)){if(h[1])return p(e.getElementsByTagName(b),f);if(h[2]&&l.find.CLASS&&e.getElementsByClassName)return p(e.getElementsByClassName(h[2]),f)}if(e.nodeType===9){if(b==="body"&&e.body)return p([e.body],f);if(h&&h[3]){var i=e.getElementById(h[3]);if(!i||!i.parentNode)return p([],f);if(i.id===h[3])return p([i],f)}try{return p(e.querySelectorAll(b),f)}catch(j){}}else if(e.nodeType===1&&e.nodeName.toLowerCase()!=="object"){var m=e,n=e.getAttribute("id"),o=n||d,q=e.parentNode,r=/^\s*[+~]/.test(b);n?o=o.replace(/'/g,"\\$&"):e.setAttribute("id",o),r&&q&&(e=e.parentNode);try{if(!r||q)return p(e.querySelectorAll("[id='"+o+"'] "+b),f)}catch(s){}finally{n||m.removeAttribute("id")}}}return a(b,e,f,g)};for(var e in a)k[e]=a[e];b=null}}(),function(){var a=c.documentElement,b=a.matchesSelector||a.mozMatchesSelector||a.webkitMatchesSelector||a.msMatchesSelector;if(b){var d=!b.call(c.createElement("div"),"div"),e=!1;try{b.call(c.documentElement,"[test!='']:sizzle")}catch(f){e=!0}k.matchesSelector=function(a,c){c=c.replace(/\=\s*([^'"\]]*)\s*\]/g,"='$1']");if(!k.isXML(a))try{if(e||!l.match.PSEUDO.test(c)&&!/!=/.test(c)){var f=b.call(a,c);if(f||!d||a.document&&a.document.nodeType!==11)return f}}catch(g){}return k(c,null,null,[a]).length>0}}}(),function(){var a=c.createElement("div");a.innerHTML="
";if(!!a.getElementsByClassName&&a.getElementsByClassName("e").length!==0){a.lastChild.className="e";if(a.getElementsByClassName("e").length===1)return;l.order.splice(1,0,"CLASS"),l.find.CLASS=function(a,b,c){if(typeof b.getElementsByClassName!="undefined"&&!c)return b.getElementsByClassName(a[1])},a=null}}(),c.documentElement.contains?k.contains=function(a,b){return a!==b&&(a.contains?a.contains(b):!0)}:c.documentElement.compareDocumentPosition?k.contains=function(a,b){return!!(a.compareDocumentPosition(b)&16)}:k.contains=function(){return!1},k.isXML=function(a){var b=(a?a.ownerDocument||a:0).documentElement;return b?b.nodeName!=="HTML":!1};var v=function(a,b){var c,d=[],e="",f=b.nodeType?[b]:b;while(c=l.match.PSEUDO.exec(a))e+=c[0],a=a.replace(l.match.PSEUDO,"");a=l.relative[a]?a+"*":a;for(var g=0,h=f.length;g0)for(h=g;h0:this.filter(a).length>0)},closest:function(a,b){var c=[],d,e,g=this[0];if(f.isArray(a)){var h,i,j={},k=1;if(g&&a.length){for(d=0,e=a.length;d-1:f(g).is(h))&&c.push({selector:i,elem:g,level:k});g=g.parentNode,k++}}return c}var l=S.test(a)||typeof a!="string"?f(a,b||this.context):0;for(d=0,e=this.length;d-1:f.find.matchesSelector(g,a)){c.push(g);break}g=g.parentNode;if(!g||!g.ownerDocument||g===b||g.nodeType===11)break}}c=c.length>1?f.unique(c):c;return this.pushStack(c,"closest",a)},index:function(a){if(!a)return this[0]&&this[0].parentNode?this.prevAll().length:-1;if(typeof a=="string")return f.inArray(this[0],f(a));return f.inArray(a.jquery?a[0]:a,this)},add:function(a,b){var c=typeof a=="string"?f(a,b):f.makeArray(a&&a.nodeType?[a]:a),d=f.merge(this.get(),c);return this.pushStack(U(c[0])||U(d[0])?d:f.unique(d))},andSelf:function(){return this.add(this.prevObject)}}),f.each({parent:function(a){var b=a.parentNode;return b&&b.nodeType!==11?b:null},parents:function(a){return f.dir(a,"parentNode")},parentsUntil:function(a,b,c){return f.dir(a,"parentNode",c)},next:function(a){return f.nth(a,2,"nextSibling")},prev:function(a){return f.nth(a,2,"previousSibling")},nextAll:function(a){return f.dir(a,"nextSibling")},prevAll:function(a){return f.dir(a,"previousSibling")},nextUntil:function(a,b,c){return f.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return f.dir(a,"previousSibling",c)},siblings:function(a){return f.sibling(a.parentNode.firstChild,a)},children:function(a){return f.sibling(a.firstChild)},contents:function(a){return f.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:f.makeArray(a.childNodes)}},function(a,b){f.fn[a]=function(c,d){var e=f.map(this,b,c),g=R.call(arguments);N.test(a)||(d=c),d&&typeof d=="string"&&(e=f.filter(d,e)),e=this.length>1&&!T[a]?f.unique(e):e,(this.length>1||P.test(d))&&O.test(a)&&(e=e.reverse());return this.pushStack(e,a,g.join(","))}}),f.extend({filter:function(a,b,c){c&&(a=":not("+a+")");return b.length===1?f.find.matchesSelector(b[0],a)?[b[0]]:[]:f.find.matches(a,b)},dir:function(a,c,d){var e=[],g=a[c];while(g&&g.nodeType!==9&&(d===b||g.nodeType!==1||!f(g).is(d)))g.nodeType===1&&e.push(g),g=g[c];return e},nth:function(a,b,c,d){b=b||1;var e=0;for(;a;a=a[c])if(a.nodeType===1&&++e===b)break;return a},sibling:function(a,b){var c=[];for(;a;a=a.nextSibling)a.nodeType===1&&a!==b&&c.push(a);return c}});var W=/ jQuery\d+="(?:\d+|null)"/g,X=/^\s+/,Y=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig,Z=/<([\w:]+)/,$=/",""],legend:[1,"
","
"],thead:[1,"","
"],tr:[2,"","
"],td:[3,"","
"],col:[2,"","
"],area:[1,"",""],_default:[0,"",""]};be.optgroup=be.option,be.tbody=be.tfoot=be.colgroup=be.caption=be.thead,be.th=be.td,f.support.htmlSerialize||(be._default=[1,"div
","
"]),f.fn.extend({text:function(a){if(f.isFunction(a))return this.each(function(b){var c=f(this);c.text(a.call(this,b,c.text()))});if(typeof a!="object"&&a!==b)return this.empty().append((this[0]&&this[0].ownerDocument||c).createTextNode(a));return f.text(this)},wrapAll:function(a){if(f.isFunction(a))return this.each(function(b){f(this).wrapAll(a.call(this,b))});if(this[0]){var b=f(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstChild&&a.firstChild.nodeType===1)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){if(f.isFunction(a))return this.each(function(b){f(this).wrapInner(a.call(this,b))});return this.each(function(){var b=f(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){return this.each(function(){f(this).wrapAll(a)})},unwrap:function(){return this.parent().each(function(){f.nodeName(this,"body")||f(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.appendChild(a)})},prepend:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.insertBefore(a,this.firstChild)})},before:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this)});if(arguments.length){var a=f(arguments[0]);a.push.apply(a,this.toArray());return this.pushStack(a,"before",arguments)}},after:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this.nextSibling)});if(arguments.length){var a=this.pushStack(this,"after",arguments);a.push.apply(a,f(arguments[0]).toArray());return a}},remove:function(a,b){for(var c=0,d;(d=this[c])!=null;c++)if(!a||f.filter(a,[d]).length)!b&&d.nodeType===1&&(f.cleanData(d.getElementsByTagName("*")),f.cleanData([d])),d.parentNode&&d.parentNode.removeChild(d);return this},empty:function(){for(var a=0,b;(b=this[a])!=null;a++){b.nodeType===1&&f.cleanData(b.getElementsByTagName("*"));while(b.firstChild)b.removeChild(b.firstChild)}return this},clone:function(a,b){a=a==null?!1:a,b=b==null?a:b;return this.map(function(){return f.clone(this,a,b)})},html:function(a){if(a===b)return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(W,""):null;if(typeof a=="string"&&!ba.test(a)&&(f.support.leadingWhitespace||!X.test(a))&&!be[(Z.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(Y,"<$1>");try{for(var c=0,d=this.length;c1&&l0?this.clone(!0):this).get();f(e[h])[b](j),d=d.concat(j)}return this.pushStack(d,a,e.selector)}}),f.extend({clone:function(a,b,c){var d=a.cloneNode(!0),e,g,h;if((!f.support.noCloneEvent||!f.support.noCloneChecked)&&(a.nodeType===1||a.nodeType===11)&&!f.isXMLDoc(a)){bh(a,d),e=bi(a),g=bi(d);for(h=0;e[h];++h)g[h]&&bh(e[h],g[h])}if(b){bg(a,d);if(c){e=bi(a),g=bi(d);for(h=0;e[h];++h)bg(e[h],g[h])}}e=g=null;return d},clean:function(a,b,d,e){var g;b=b||c,typeof b.createElement=="undefined"&&(b=b.ownerDocument||b[0]&&b[0].ownerDocument||c);var h=[],i;for(var j=0,k;(k=a[j])!=null;j++){typeof k=="number"&&(k+="");if(!k)continue;if(typeof k=="string")if(!_.test(k))k=b.createTextNode(k);else{k=k.replace(Y,"<$1>");var l=(Z.exec(k)||["",""])[1].toLowerCase(),m=be[l]||be._default,n=m[0],o=b.createElement("div");o.innerHTML=m[1]+k+m[2];while(n--)o=o.lastChild;if(!f.support.tbody){var p=$.test(k),q=l==="table"&&!p?o.firstChild&&o.firstChild.childNodes:m[1]===""&&!p?o.childNodes:[];for(i=q.length-1;i>=0;--i)f.nodeName(q[i],"tbody")&&!q[i].childNodes.length&&q[i].parentNode.removeChild(q[i])}!f.support.leadingWhitespace&&X.test(k)&&o.insertBefore(b.createTextNode(X.exec(k)[0]),o.firstChild),k=o.childNodes}var r;if(!f.support.appendChecked)if(k[0]&&typeof (r=k.length)=="number")for(i=0;i=0)return b+"px"}}}),f.support.opacity||(f.cssHooks.opacity={get:function(a,b){return bn.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?parseFloat(RegExp.$1)/100+"":b?"1":""},set:function(a,b){var c=a.style,d=a.currentStyle,e=f.isNaN(b)?"":"alpha(opacity="+b*100+")",g=d&&d.filter||c.filter||"";c.zoom=1;if(b>=1&&f.trim(g.replace(bm,""))===""){c.removeAttribute("filter");if(d&&!d.filter)return}c.filter=bm.test(g)?g.replace(bm,e):g+" "+e}}),f(function(){f.support.reliableMarginRight||(f.cssHooks.marginRight={get:function(a,b){var c;f.swap(a,{display:"inline-block"},function(){b?c=bv(a,"margin-right","marginRight"):c=a.style.marginRight});return c}})}),c.defaultView&&c.defaultView.getComputedStyle&&(bw=function(a,c){var d,e,g;c=c.replace(bo,"-$1").toLowerCase();if(!(e=a.ownerDocument.defaultView))return b;if(g=e.getComputedStyle(a,null))d=g.getPropertyValue(c),d===""&&!f.contains(a.ownerDocument.documentElement,a)&&(d=f.style(a,c));return d}),c.documentElement.currentStyle&&(bx=function(a,b){var c,d=a.currentStyle&&a.currentStyle[b],e=a.runtimeStyle&&a.runtimeStyle[b],f=a.style;!bp.test(d)&&bq.test(d)&&(c=f.left,e&&(a.runtimeStyle.left=a.currentStyle.left),f.left=b==="fontSize"?"1em":d||0,d=f.pixelLeft+"px",f.left=c,e&&(a.runtimeStyle.left=e));return d===""?"auto":d}),bv=bw||bx,f.expr&&f.expr.filters&&(f.expr.filters.hidden=function(a){var b=a.offsetWidth,c=a.offsetHeight;return b===0&&c===0||!f.support.reliableHiddenOffsets&&(a.style.display||f.css(a,"display"))==="none"},f.expr.filters.visible=function(a){return!f.expr.filters.hidden(a)});var bz=/%20/g,bA=/\[\]$/,bB=/\r?\n/g,bC=/#.*$/,bD=/^(.*?):[ \t]*([^\r\n]*)\r?$/mg,bE=/^(?:color|date|datetime|datetime-local|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i,bF=/^(?:about|app|app\-storage|.+\-extension|file|res|widget):$/,bG=/^(?:GET|HEAD)$/,bH=/^\/\//,bI=/\?/,bJ=/)<[^<]*)*<\/script>/gi,bK=/^(?:select|textarea)/i,bL=/\s+/,bM=/([?&])_=[^&]*/,bN=/^([\w\+\.\-]+:)(?:\/\/([^\/?#:]*)(?::(\d+))?)?/,bO=f.fn.load,bP={},bQ={},bR,bS,bT=["*/"]+["*"];try{bR=e.href}catch(bU){bR=c.createElement("a"),bR.href="",bR=bR.href}bS=bN.exec(bR.toLowerCase())||[],f.fn.extend({load:function(a,c,d){if(typeof a!="string"&&bO)return bO.apply(this,arguments);if(!this.length)return this;var e=a.indexOf(" ");if(e>=0){var g=a.slice(e,a.length);a=a.slice(0,e)}var h="GET";c&&(f.isFunction(c)?(d=c,c=b):typeof c=="object"&&(c=f.param(c,f.ajaxSettings.traditional),h="POST"));var i=this;f.ajax({url:a,type:h,dataType:"html",data:c,complete:function(a,b,c){c=a.responseText,a.isResolved()&&(a.done(function(a){c=a}),i.html(g?f("
").append(c.replace(bJ,"")).find(g):c)),d&&i.each(d,[c,b,a])}});return this},serialize:function(){return f.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?f.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||bK.test(this.nodeName)||bE.test(this.type))}).map(function(a,b){var c=f(this).val();return c==null?null:f.isArray(c)?f.map(c,function(a,c){return{name:b.name,value:a.replace(bB,"\r\n")}}):{name:b.name,value:c.replace(bB,"\r\n")}}).get()}}),f.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "),function(a,b){f.fn[b]=function(a){return this.bind(b,a)}}),f.each(["get","post"],function(a,c){f[c]=function(a,d,e,g){f.isFunction(d)&&(g=g||e,e=d,d=b);return f.ajax({type:c,url:a,data:d,success:e,dataType:g})}}),f.extend({getScript:function(a,c){return f.get(a,b,c,"script")},getJSON:function(a,b,c){return f.get(a,b,c,"json")},ajaxSetup:function(a,b){b?bX(a,f.ajaxSettings):(b=a,a=f.ajaxSettings),bX(a,b);return a},ajaxSettings:{url:bR,isLocal:bF.test(bS[1]),global:!0,type:"GET",contentType:"application/x-www-form-urlencoded",processData:!0,async:!0,accepts:{xml:"application/xml, text/xml",html:"text/html",text:"text/plain",json:"application/json, text/javascript","*":bT},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText"},converters:{"* text":a.String,"text html":!0,"text json":f.parseJSON,"text xml":f.parseXML},flatOptions:{context:!0,url:!0}},ajaxPrefilter:bV(bP),ajaxTransport:bV(bQ),ajax:function(a,c){function w(a,c,l,m){if(s!==2){s=2,q&&clearTimeout(q),p=b,n=m||"",v.readyState=a>0?4:0;var o,r,u,w=c,x=l?bZ(d,v,l):b,y,z;if(a>=200&&a<300||a===304){if(d.ifModified){if(y=v.getResponseHeader("Last-Modified"))f.lastModified[k]=y;if(z=v.getResponseHeader("Etag"))f.etag[k]=z}if(a===304)w="notmodified",o=!0;else try{r=b$(d,x),w="success",o=!0}catch(A){w="parsererror",u=A}}else{u=w;if(!w||a)w="error",a<0&&(a=0)}v.status=a,v.statusText=""+(c||w),o?h.resolveWith(e,[r,w,v]):h.rejectWith(e,[v,w,u]),v.statusCode(j),j=b,t&&g.trigger("ajax"+(o?"Success":"Error"),[v,d,o?r:u]),i.resolveWith(e,[v,w]),t&&(g.trigger("ajaxComplete",[v,d]),--f.active||f.event.trigger("ajaxStop"))}}typeof a=="object"&&(c=a,a=b),c=c||{};var d=f.ajaxSetup({},c),e=d.context||d,g=e!==d&&(e.nodeType||e instanceof f)?f(e):f.event,h=f.Deferred(),i=f._Deferred(),j=d.statusCode||{},k,l={},m={},n,o,p,q,r,s=0,t,u,v={readyState:0,setRequestHeader:function(a,b){if(!s){var c=a.toLowerCase();a=m[c]=m[c]||a,l[a]=b}return this},getAllResponseHeaders:function(){return s===2?n:null},getResponseHeader:function(a){var c;if(s===2){if(!o){o={};while(c=bD.exec(n))o[c[1].toLowerCase()]=c[2]}c=o[a.toLowerCase()]}return c===b?null:c},overrideMimeType:function(a){s||(d.mimeType=a);return this},abort:function(a){a=a||"abort",p&&p.abort(a),w(0,a);return this}};h.promise(v),v.success=v.done,v.error=v.fail,v.complete=i.done,v.statusCode=function(a){if(a){var b;if(s<2)for(b in a)j[b]=[j[b],a[b]];else b=a[v.status],v.then(b,b)}return this},d.url=((a||d.url)+"").replace(bC,"").replace(bH,bS[1]+"//"),d.dataTypes=f.trim(d.dataType||"*").toLowerCase().split(bL),d.crossDomain==null&&(r=bN.exec(d.url.toLowerCase()),d.crossDomain=!(!r||r[1]==bS[1]&&r[2]==bS[2]&&(r[3]||(r[1]==="http:"?80:443))==(bS[3]||(bS[1]==="http:"?80:443)))),d.data&&d.processData&&typeof d.data!="string"&&(d.data=f.param(d.data,d.traditional)),bW(bP,d,c,v);if(s===2)return!1;t=d.global,d.type=d.type.toUpperCase(),d.hasContent=!bG.test(d.type),t&&f.active++===0&&f.event.trigger("ajaxStart");if(!d.hasContent){d.data&&(d.url+=(bI.test(d.url)?"&":"?")+d.data,delete d.data),k=d.url;if(d.cache===!1){var x=f.now(),y=d.url.replace(bM,"$1_="+x);d.url=y+(y===d.url?(bI.test(d.url)?"&":"?")+"_="+x:"")}}(d.data&&d.hasContent&&d.contentType!==!1||c.contentType)&&v.setRequestHeader("Content-Type",d.contentType),d.ifModified&&(k=k||d.url,f.lastModified[k]&&v.setRequestHeader("If-Modified-Since",f.lastModified[k]),f.etag[k]&&v.setRequestHeader("If-None-Match",f.etag[k])),v.setRequestHeader("Accept",d.dataTypes[0]&&d.accepts[d.dataTypes[0]]?d.accepts[d.dataTypes[0]]+(d.dataTypes[0]!=="*"?", "+bT+"; q=0.01":""):d.accepts["*"]);for(u in d.headers)v.setRequestHeader(u,d.headers[u]);if(d.beforeSend&&(d.beforeSend.call(e,v,d)===!1||s===2)){v.abort();return!1}for(u in{success:1,error:1,complete:1})v[u](d[u]);p=bW(bQ,d,c,v);if(!p)w(-1,"No Transport");else{v.readyState=1,t&&g.trigger("ajaxSend",[v,d]),d.async&&d.timeout>0&&(q=setTimeout(function(){v.abort("timeout")},d.timeout));try{s=1,p.send(l,w)}catch(z){s<2?w(-1,z):f.error(z)}}return v},param:function(a,c){var d=[],e=function(a,b){b=f.isFunction(b)?b():b,d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(b)};c===b&&(c=f.ajaxSettings.traditional);if(f.isArray(a)||a.jquery&&!f.isPlainObject(a))f.each(a,function(){e(this.name,this.value)});else for(var g in a)bY(g,a[g],c,e);return d.join("&").replace(bz,"+")}}),f.extend({active:0,lastModified:{},etag:{}});var b_=f.now(),ca=/(\=)\?(&|$)|\?\?/i;f.ajaxSetup({jsonp:"callback",jsonpCallback:function(){return f.expando+"_"+b_++}}),f.ajaxPrefilter("json jsonp",function(b,c,d){var e=b.contentType==="application/x-www-form-urlencoded"&&typeof b.data=="string";if(b.dataTypes[0]==="jsonp"||b.jsonp!==!1&&(ca.test(b.url)||e&&ca.test(b.data))){var g,h=b.jsonpCallback=f.isFunction(b.jsonpCallback)?b.jsonpCallback():b.jsonpCallback,i=a[h],j=b.url,k=b.data,l="$1"+h+"$2";b.jsonp!==!1&&(j=j.replace(ca,l),b.url===j&&(e&&(k=k.replace(ca,l)),b.data===k&&(j+=(/\?/.test(j)?"&":"?")+b.jsonp+"="+h))),b.url=j,b.data=k,a[h]=function(a){g=[a]},d.always(function(){a[h]=i,g&&f.isFunction(i)&&a[h](g[0])}),b.converters["script json"]=function(){g||f.error(h+" was not called");return g[0]},b.dataTypes[0]="json";return"script"}}),f.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/javascript|ecmascript/},converters:{"text script":function(a){f.globalEval(a);return a}}}),f.ajaxPrefilter("script",function(a){a.cache===b&&(a.cache=!1),a.crossDomain&&(a.type="GET",a.global=!1)}),f.ajaxTransport("script",function(a){if(a.crossDomain){var d,e=c.head||c.getElementsByTagName("head")[0]||c.documentElement;return{send:function(f,g){d=c.createElement("script"),d.async="async",a.scriptCharset&&(d.charset=a.scriptCharset),d.src=a.url,d.onload=d.onreadystatechange=function(a,c){if(c||!d.readyState||/loaded|complete/.test(d.readyState))d.onload=d.onreadystatechange=null,e&&d.parentNode&&e.removeChild(d),d=b,c||g(200,"success")},e.insertBefore(d,e.firstChild)},abort:function(){d&&d.onload(0,1)}}}});var cb=a.ActiveXObject?function(){for(var a in cd)cd[a](0,1)}:!1,cc=0,cd;f.ajaxSettings.xhr=a.ActiveXObject?function(){return!this.isLocal&&ce()||cf()}:ce,function(a){f.extend(f.support,{ajax:!!a,cors:!!a&&"withCredentials"in a})}(f.ajaxSettings.xhr()),f.support.ajax&&f.ajaxTransport(function(c){if(!c.crossDomain||f.support.cors){var d;return{send:function(e,g){var h=c.xhr(),i,j;c.username?h.open(c.type,c.url,c.async,c.username,c.password):h.open(c.type,c.url,c.async);if(c.xhrFields)for(j in c.xhrFields)h[j]=c.xhrFields[j];c.mimeType&&h.overrideMimeType&&h.overrideMimeType(c.mimeType),!c.crossDomain&&!e["X-Requested-With"]&&(e["X-Requested-With"]="XMLHttpRequest");try{for(j in e)h.setRequestHeader(j,e[j])}catch(k){}h.send(c.hasContent&&c.data||null),d=function(a,e){var j,k,l,m,n;try{if(d&&(e||h.readyState===4)){d=b,i&&(h.onreadystatechange=f.noop,cb&&delete cd[i]);if(e)h.readyState!==4&&h.abort();else{j=h.status,l=h.getAllResponseHeaders(),m={},n=h.responseXML,n&&n.documentElement&&(m.xml=n),m.text=h.responseText;try{k=h.statusText}catch(o){k=""}!j&&c.isLocal&&!c.crossDomain?j=m.text?200:404:j===1223&&(j=204)}}}catch(p){e||g(-1,p)}m&&g(j,k,m,l)},!c.async||h.readyState===4?d():(i=++cc,cb&&(cd||(cd={},f(a).unload(cb)),cd[i]=d),h.onreadystatechange=d)},abort:function(){d&&d(0,1)}}}});var cg={},ch,ci,cj=/^(?:toggle|show|hide)$/,ck=/^([+\-]=)?([\d+.\-]+)([a-z%]*)$/i,cl,cm=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]],cn;f.fn.extend({show:function(a,b,c){var d,e;if(a||a===0)return this.animate(cq("show",3),a,b,c);for(var g=0,h=this.length;g=e.duration+this.startTime){this.now=this.end,this.pos=this.state=1,this.update(),e.animatedProperties[this.prop]=!0;for(g in e.animatedProperties)e.animatedProperties[g]!==!0&&(c=!1);if(c){e.overflow!=null&&!f.support.shrinkWrapBlocks&&f.each(["","X","Y"],function(a,b){d.style["overflow"+b]=e.overflow[a]}),e.hide&&f(d).hide();if(e.hide||e.show)for(var i in e.animatedProperties)f.style(d,i,e.orig[i]);e.complete.call(d)}return!1}e.duration==Infinity?this.now=b:(h=b-this.startTime,this.state=h/e.duration,this.pos=f.easing[e.animatedProperties[this.prop]](this.state,h,0,1,e.duration),this.now=this.start+(this.end-this.start)*this.pos),this.update();return!0}},f.extend(f.fx,{tick:function(){for(var a=f.timers,b=0;b
";f.extend(b.style,{position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"}),b.innerHTML=j,a.insertBefore(b,a.firstChild),d=b.firstChild,e=d.firstChild,h=d.nextSibling.firstChild.firstChild,this.doesNotAddBorder=e.offsetTop!==5,this.doesAddBorderForTableAndCells=h.offsetTop===5,e.style.position="fixed",e.style.top="20px",this.supportsFixedPosition=e.offsetTop===20||e.offsetTop===15,e.style.position=e.style.top="",d.style.overflow="hidden",d.style.position="relative",this.subtractsBorderForOverflowNotVisible=e.offsetTop===-5,this.doesNotIncludeMarginInBodyOffset=a.offsetTop!==i,a.removeChild(b),f.offset.initialize=f.noop},bodyOffset:function(a){var b=a.offsetTop,c=a.offsetLeft;f.offset.initialize(),f.offset.doesNotIncludeMarginInBodyOffset&&(b+=parseFloat(f.css(a,"marginTop"))||0,c+=parseFloat(f.css(a,"marginLeft"))||0);return{top:b,left:c}},setOffset:function(a,b,c){var d=f.css(a,"position");d==="static"&&(a.style.position="relative");var e=f(a),g=e.offset(),h=f.css(a,"top"),i=f.css(a,"left"),j=(d==="absolute"||d==="fixed")&&f.inArray("auto",[h,i])>-1,k={},l={},m,n;j?(l=e.position(),m=l.top,n=l.left):(m=parseFloat(h)||0,n=parseFloat(i)||0),f.isFunction(b)&&(b=b.call(a,c,g)),b.top!=null&&(k.top=b.top-g.top+m),b.left!=null&&(k.left=b.left-g.left+n),"using"in b?b.using.call(a,k):e.css(k)}},f.fn.extend({position:function(){if(!this[0])return null;var a=this[0],b=this.offsetParent(),c=this.offset(),d=ct.test(b[0].nodeName)?{top:0,left:0}:b.offset();c.top-=parseFloat(f.css(a,"marginTop"))||0,c.left-=parseFloat(f.css(a,"marginLeft"))||0,d.top+=parseFloat(f.css(b[0],"borderTopWidth"))||0,d.left+=parseFloat(f.css(b[0],"borderLeftWidth"))||0;return{top:c.top-d.top,left:c.left-d.left}},offsetParent:function(){return this.map(function(){var a=this.offsetParent||c.body;while(a&&!ct.test(a.nodeName)&&f.css(a,"position")==="static")a=a.offsetParent;return a})}}),f.each(["Left","Top"],function(a,c){var d="scroll"+c;f.fn[d]=function(c){var e,g;if(c===b){e=this[0];if(!e)return null;g=cu(e);return g?"pageXOffset"in g?g[a?"pageYOffset":"pageXOffset"]:f.support.boxModel&&g.document.documentElement[d]||g.document.body[d]:e[d]}return this.each(function(){g=cu(this),g?g.scrollTo(a?f(g).scrollLeft():c,a?c:f(g).scrollTop()):this[d]=c})}}),f.each(["Height","Width"],function(a,c){var d=c.toLowerCase();f.fn["inner"+c]=function(){var a=this[0];return a&&a.style?parseFloat(f.css(a,d,"padding")):null},f.fn["outer"+c]=function(a){var b=this[0];return b&&b.style?parseFloat(f.css(b,d,a?"margin":"border")):null},f.fn[d]=function(a){var e=this[0];if(!e)return a==null?null:this;if(f.isFunction(a))return this.each(function(b){var c=f(this);c[d](a.call(this,b,c[d]()))});if(f.isWindow(e)){var g=e.document.documentElement["client"+c],h=e.document.body;return e.document.compatMode==="CSS1Compat"&&g||h&&h["client"+c]||g}if(e.nodeType===9)return Math.max(e.documentElement["client"+c],e.body["scroll"+c],e.documentElement["scroll"+c],e.body["offset"+c],e.documentElement["offset"+c]);if(a===b){var i=f.css(e,d),j=parseFloat(i);return f.isNaN(j)?i:j}return this.css(d,typeof a=="string"?a:a+"px")}}),a.jQuery=a.$=f})(window); \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi.sln b/WebApiSamples/C#/TestLersApi.sln new file mode 100644 index 0000000..73ee08d --- /dev/null +++ b/WebApiSamples/C#/TestLersApi.sln @@ -0,0 +1,20 @@ + +Microsoft Visual Studio Solution File, Format Version 14.00 +# Visual Studio 2014 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "TestLersApi", "TestLersApi\TestLersApi.csproj", "{2FC726F6-54C4-4A5F-A572-D2C717E39D18}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|x86 = Debug|x86 + Release|x86 = Release|x86 + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {2FC726F6-54C4-4A5F-A572-D2C717E39D18}.Debug|x86.ActiveCfg = Debug|x86 + {2FC726F6-54C4-4A5F-A572-D2C717E39D18}.Debug|x86.Build.0 = Debug|x86 + {2FC726F6-54C4-4A5F-A572-D2C717E39D18}.Release|x86.ActiveCfg = Release|x86 + {2FC726F6-54C4-4A5F-A572-D2C717E39D18}.Release|x86.Build.0 = Release|x86 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/WebApiSamples/C#/TestLersApi/Program.cs b/WebApiSamples/C#/TestLersApi/Program.cs new file mode 100644 index 0000000..5eff819 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Program.cs @@ -0,0 +1,77 @@ +using System; + +namespace TestLersApi +{ + class Program + { + static void Main(string[] args) + { + // Создаем прокси класс для работы со службой + LersApi.Api client = new LersApi.Api(); + + // Устанавливаем куки-контейнер, необходим для авторизации пользователя + client.CookieContainer = new System.Net.CookieContainer(); + + // Входим в систему ЛЭРС УЧЕТ + var response = client.Login("demo", "demo"); + + // Если произошла ошибка, прекращаем работу + if (response.ErrorCode != LersApi.ErrorCode.None) + { + Console.WriteLine(response.ErrorMessage); + Console.ReadKey(); + return; + } + + // Получаем список точек учета + var response2 = client.GetMeasurePointList(); + + // Если список пустой, выходим + if (response2.MeasurePointList == null || response2.MeasurePointList.Length == 0) + { + Console.WriteLine("Список точек учета пуст"); + Console.ReadKey(); + return; + } + + // Получаем список объектов учета + var response4 = client.GetNodeListExtended(LersApi.NodeInfoFlags.Customer | LersApi.NodeInfoFlags.Systems | LersApi.NodeInfoFlags.Serviceman | LersApi.NodeInfoFlags.ServiceCompany); + + // Если список пустой, выходим + if (response4.NodeList == null || response4.NodeList.Length == 0) + { + Console.WriteLine("Список объектов учета пуст"); + Console.ReadKey(); + return; + } + + // Получаем потребление по первой точке учета из списка + var endDate = DateTime.Today; + + var startDate = new DateTime(endDate.Year-1, endDate.Month, 1); + + var response3 = client.GetMeasurePointConsumption(response2.MeasurePointList[0].Id, startDate, endDate, LersApi.DeviceDataType.Day); + + // Если список пустой, выходим + if (response3.Data == null || response3.Data.Length == 0) + { + Console.WriteLine("По точке учета нет данных потребления"); + Console.ReadKey(); + return; + } + + if (response3.Data[0].ResourceKind == LersApi.ResourceKind.Water) + { + Console.WriteLine(response3.Data[0].DateTime + ": " + ((LersApi.WaterConsumptionRecord)response3.Data[0]).T_in); + } + else + Console.WriteLine(response3.Data[0].DateTime); + + // Экспорт данных в формат XML 80020 + var response5 = client.ExportMeasurePointDataToXml80020(response2.MeasurePointList[0].Id, startDate, endDate); + + Console.ReadKey(); + return; + } + } +} diff --git a/WebApiSamples/C#/TestLersApi/Properties/AssemblyInfo.cs b/WebApiSamples/C#/TestLersApi/Properties/AssemblyInfo.cs new file mode 100644 index 0000000..438da4a --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Properties/AssemblyInfo.cs @@ -0,0 +1,36 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// Управление общими сведениями о сборке осуществляется с помощью +// набора атрибутов. Измените значения этих атрибутов, чтобы изменить сведения, +// связанные со сборкой. +[assembly: AssemblyTitle("TestLersApi")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("TestLersApi")] +[assembly: AssemblyCopyright("Copyright © 2012")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// Параметр ComVisible со значением FALSE делает типы в сборке невидимыми +// для COM-компонентов. Если требуется обратиться к типу в этой сборке через +// COM, задайте атрибуту ComVisible значение TRUE для этого типа. +[assembly: ComVisible(false)] + +// Следующий GUID служит для идентификации библиотеки типов, если этот проект будет видимым для COM +[assembly: Guid("0569e27a-c2b3-4e8b-be59-757a7c839d0c")] + +// Сведения о версии сборки состоят из следующих четырех значений: +// +// Основной номер версии +// Дополнительный номер версии +// Номер построения +// Редакция +// +// Можно задать все значения или принять номер построения и номер редакции по умолчанию, +// используя "*", как показано ниже: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/WebApiSamples/C#/TestLersApi/Properties/Settings.Designer.cs b/WebApiSamples/C#/TestLersApi/Properties/Settings.Designer.cs new file mode 100644 index 0000000..94fafff --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Properties/Settings.Designer.cs @@ -0,0 +1,36 @@ +//------------------------------------------------------------------------------ +// +// Этот код создан программой. +// Исполняемая версия:4.0.30319.269 +// +// Изменения в этом файле могут привести к неправильной работе и будут потеряны в случае +// повторной генерации кода. +// +//------------------------------------------------------------------------------ + +namespace TestLersApi.Properties { + + + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "10.0.0.0")] + internal sealed partial class Settings : global::System.Configuration.ApplicationSettingsBase { + + private static Settings defaultInstance = ((Settings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new Settings()))); + + public static Settings Default { + get { + return defaultInstance; + } + } + + [global::System.Configuration.ApplicationScopedSettingAttribute()] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Configuration.SpecialSettingAttribute(global::System.Configuration.SpecialSetting.WebServiceUrl)] + [global::System.Configuration.DefaultSettingValueAttribute("http://localhost:54025/api.asmx")] + public string TestLersApi_LersApi_Api { + get { + return ((string)(this["TestLersApi_LersApi_Api"])); + } + } + } +} diff --git a/WebApiSamples/C#/TestLersApi/Properties/Settings.settings b/WebApiSamples/C#/TestLersApi/Properties/Settings.settings new file mode 100644 index 0000000..c7e01db --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Properties/Settings.settings @@ -0,0 +1,9 @@ + + + + + + http://localhost:54025/api.asmx + + + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/TestLersApi.csproj b/WebApiSamples/C#/TestLersApi/TestLersApi.csproj new file mode 100644 index 0000000..8a18a57 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/TestLersApi.csproj @@ -0,0 +1,133 @@ + + + + Debug + x86 + 8.0.30703 + 2.0 + {2FC726F6-54C4-4A5F-A572-D2C717E39D18} + Exe + Properties + TestLersApi + TestLersApi + v4.0 + Client + 512 + + + x86 + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + + + x86 + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + + + + + + + + + + + + + + + + + True + True + Settings.settings + + + True + True + Reference.map + + + + + + + + Dynamic + Web References\LersApi\ + http://localhost:54025/api.asmx + + + + + Settings + TestLersApi_LersApi_Api + + + + + + SettingsSingleFileGenerator + Settings.Designer.cs + + + + MSDiscoCodeGenerator + Reference.cs + + + Reference.map + + + Reference.map + + + Reference.map + + + Reference.map + + + Reference.map + + + Reference.map + + + Reference.map + + + Reference.map + + + Reference.map + + + Reference.map + + + Reference.map + + + + + + + + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/Reference.cs b/WebApiSamples/C#/TestLersApi/Web References/LersApi/Reference.cs new file mode 100644 index 0000000..d915727 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/Reference.cs @@ -0,0 +1,4230 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +// +// This source code was auto-generated by Microsoft.VSDesigner, Version 4.0.30319.42000. +// +#pragma warning disable 1591 + +namespace TestLersApi.LersApi { + using System; + using System.Web.Services; + using System.Diagnostics; + using System.Web.Services.Protocols; + using System.Xml.Serialization; + using System.ComponentModel; + + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Web.Services.WebServiceBindingAttribute(Name="ApiSoap", Namespace="http://www.lers.ru/website/api")] + public partial class Api : System.Web.Services.Protocols.SoapHttpClientProtocol { + + private System.Threading.SendOrPostCallback LoginOperationCompleted; + + private System.Threading.SendOrPostCallback LogoutOperationCompleted; + + private System.Threading.SendOrPostCallback GetMeasurePointByIdOperationCompleted; + + private System.Threading.SendOrPostCallback GetMeasurePointByIdExtendedOperationCompleted; + + private System.Threading.SendOrPostCallback GetMeasurePointByNumberOperationCompleted; + + private System.Threading.SendOrPostCallback GetMeasurePointByNumberExtendedOperationCompleted; + + private System.Threading.SendOrPostCallback GetNodeByIdOperationCompleted; + + private System.Threading.SendOrPostCallback GetNodeByIdExtendedOperationCompleted; + + private System.Threading.SendOrPostCallback GetNodeByNumberOperationCompleted; + + private System.Threading.SendOrPostCallback GetNodeByNumberExtendedOperationCompleted; + + private System.Threading.SendOrPostCallback GetRoomByIdOperationCompleted; + + private System.Threading.SendOrPostCallback GetRoomByIdExtendedOperationCompleted; + + private System.Threading.SendOrPostCallback GetMeasurePointListOperationCompleted; + + private System.Threading.SendOrPostCallback GetNodeListOperationCompleted; + + private System.Threading.SendOrPostCallback GetNodeListExtendedOperationCompleted; + + private System.Threading.SendOrPostCallback GetMeasurePointConsumptionOperationCompleted; + + private System.Threading.SendOrPostCallback GetMeasurePointTotalsOperationCompleted; + + private System.Threading.SendOrPostCallback ExportMeasurePointDataToXml80020OperationCompleted; + + private System.Threading.SendOrPostCallback GetMeasurePointElectricPowerOperationCompleted; + + private System.Threading.SendOrPostCallback GetMeasurePointDeviceErrorsOperationCompleted; + + private bool useDefaultCredentialsSetExplicitly; + + /// + public Api() { + this.Url = global::TestLersApi.Properties.Settings.Default.TestLersApi_LersApi_Api; + if ((this.IsLocalFileSystemWebService(this.Url) == true)) { + this.UseDefaultCredentials = true; + this.useDefaultCredentialsSetExplicitly = false; + } + else { + this.useDefaultCredentialsSetExplicitly = true; + } + } + + public new string Url { + get { + return base.Url; + } + set { + if ((((this.IsLocalFileSystemWebService(base.Url) == true) + && (this.useDefaultCredentialsSetExplicitly == false)) + && (this.IsLocalFileSystemWebService(value) == false))) { + base.UseDefaultCredentials = false; + } + base.Url = value; + } + } + + public new bool UseDefaultCredentials { + get { + return base.UseDefaultCredentials; + } + set { + base.UseDefaultCredentials = value; + this.useDefaultCredentialsSetExplicitly = true; + } + } + + /// + public event LoginCompletedEventHandler LoginCompleted; + + /// + public event LogoutCompletedEventHandler LogoutCompleted; + + /// + public event GetMeasurePointByIdCompletedEventHandler GetMeasurePointByIdCompleted; + + /// + public event GetMeasurePointByIdExtendedCompletedEventHandler GetMeasurePointByIdExtendedCompleted; + + /// + public event GetMeasurePointByNumberCompletedEventHandler GetMeasurePointByNumberCompleted; + + /// + public event GetMeasurePointByNumberExtendedCompletedEventHandler GetMeasurePointByNumberExtendedCompleted; + + /// + public event GetNodeByIdCompletedEventHandler GetNodeByIdCompleted; + + /// + public event GetNodeByIdExtendedCompletedEventHandler GetNodeByIdExtendedCompleted; + + /// + public event GetNodeByNumberCompletedEventHandler GetNodeByNumberCompleted; + + /// + public event GetNodeByNumberExtendedCompletedEventHandler GetNodeByNumberExtendedCompleted; + + /// + public event GetRoomByIdCompletedEventHandler GetRoomByIdCompleted; + + /// + public event GetRoomByIdExtendedCompletedEventHandler GetRoomByIdExtendedCompleted; + + /// + public event GetMeasurePointListCompletedEventHandler GetMeasurePointListCompleted; + + /// + public event GetNodeListCompletedEventHandler GetNodeListCompleted; + + /// + public event GetNodeListExtendedCompletedEventHandler GetNodeListExtendedCompleted; + + /// + public event GetMeasurePointConsumptionCompletedEventHandler GetMeasurePointConsumptionCompleted; + + /// + public event GetMeasurePointTotalsCompletedEventHandler GetMeasurePointTotalsCompleted; + + /// + public event ExportMeasurePointDataToXml80020CompletedEventHandler ExportMeasurePointDataToXml80020Completed; + + /// + public event GetMeasurePointElectricPowerCompletedEventHandler GetMeasurePointElectricPowerCompleted; + + /// + public event GetMeasurePointDeviceErrorsCompletedEventHandler GetMeasurePointDeviceErrorsCompleted; + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/Login", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public Response Login([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] string userName, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] string password) { + object[] results = this.Invoke("Login", new object[] { + userName, + password}); + return ((Response)(results[0])); + } + + /// + public void LoginAsync(string userName, string password) { + this.LoginAsync(userName, password, null); + } + + /// + public void LoginAsync(string userName, string password, object userState) { + if ((this.LoginOperationCompleted == null)) { + this.LoginOperationCompleted = new System.Threading.SendOrPostCallback(this.OnLoginOperationCompleted); + } + this.InvokeAsync("Login", new object[] { + userName, + password}, this.LoginOperationCompleted, userState); + } + + private void OnLoginOperationCompleted(object arg) { + if ((this.LoginCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.LoginCompleted(this, new LoginCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/Logout", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public Response Logout() { + object[] results = this.Invoke("Logout", new object[0]); + return ((Response)(results[0])); + } + + /// + public void LogoutAsync() { + this.LogoutAsync(null); + } + + /// + public void LogoutAsync(object userState) { + if ((this.LogoutOperationCompleted == null)) { + this.LogoutOperationCompleted = new System.Threading.SendOrPostCallback(this.OnLogoutOperationCompleted); + } + this.InvokeAsync("Logout", new object[0], this.LogoutOperationCompleted, userState); + } + + private void OnLogoutOperationCompleted(object arg) { + if ((this.LogoutCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.LogoutCompleted(this, new LogoutCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetMeasurePointById", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetMeasurePoint GetMeasurePointById([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int measurePointId) { + object[] results = this.Invoke("GetMeasurePointById", new object[] { + measurePointId}); + return ((ResponseGetMeasurePoint)(results[0])); + } + + /// + public void GetMeasurePointByIdAsync(int measurePointId) { + this.GetMeasurePointByIdAsync(measurePointId, null); + } + + /// + public void GetMeasurePointByIdAsync(int measurePointId, object userState) { + if ((this.GetMeasurePointByIdOperationCompleted == null)) { + this.GetMeasurePointByIdOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetMeasurePointByIdOperationCompleted); + } + this.InvokeAsync("GetMeasurePointById", new object[] { + measurePointId}, this.GetMeasurePointByIdOperationCompleted, userState); + } + + private void OnGetMeasurePointByIdOperationCompleted(object arg) { + if ((this.GetMeasurePointByIdCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetMeasurePointByIdCompleted(this, new GetMeasurePointByIdCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetMeasurePointByIdExtended", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetMeasurePoint GetMeasurePointByIdExtended([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int measurePointId, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] MeasurePointInfoFlags measurePointFlags) { + object[] results = this.Invoke("GetMeasurePointByIdExtended", new object[] { + measurePointId, + measurePointFlags}); + return ((ResponseGetMeasurePoint)(results[0])); + } + + /// + public void GetMeasurePointByIdExtendedAsync(int measurePointId, MeasurePointInfoFlags measurePointFlags) { + this.GetMeasurePointByIdExtendedAsync(measurePointId, measurePointFlags, null); + } + + /// + public void GetMeasurePointByIdExtendedAsync(int measurePointId, MeasurePointInfoFlags measurePointFlags, object userState) { + if ((this.GetMeasurePointByIdExtendedOperationCompleted == null)) { + this.GetMeasurePointByIdExtendedOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetMeasurePointByIdExtendedOperationCompleted); + } + this.InvokeAsync("GetMeasurePointByIdExtended", new object[] { + measurePointId, + measurePointFlags}, this.GetMeasurePointByIdExtendedOperationCompleted, userState); + } + + private void OnGetMeasurePointByIdExtendedOperationCompleted(object arg) { + if ((this.GetMeasurePointByIdExtendedCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetMeasurePointByIdExtendedCompleted(this, new GetMeasurePointByIdExtendedCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetMeasurePointByNumber", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetMeasurePoint GetMeasurePointByNumber([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int measurePointNumber) { + object[] results = this.Invoke("GetMeasurePointByNumber", new object[] { + measurePointNumber}); + return ((ResponseGetMeasurePoint)(results[0])); + } + + /// + public void GetMeasurePointByNumberAsync(int measurePointNumber) { + this.GetMeasurePointByNumberAsync(measurePointNumber, null); + } + + /// + public void GetMeasurePointByNumberAsync(int measurePointNumber, object userState) { + if ((this.GetMeasurePointByNumberOperationCompleted == null)) { + this.GetMeasurePointByNumberOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetMeasurePointByNumberOperationCompleted); + } + this.InvokeAsync("GetMeasurePointByNumber", new object[] { + measurePointNumber}, this.GetMeasurePointByNumberOperationCompleted, userState); + } + + private void OnGetMeasurePointByNumberOperationCompleted(object arg) { + if ((this.GetMeasurePointByNumberCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetMeasurePointByNumberCompleted(this, new GetMeasurePointByNumberCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetMeasurePointByNumberExtended", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetMeasurePoint GetMeasurePointByNumberExtended([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int measurePointNumber, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] MeasurePointInfoFlags measurePointFlags) { + object[] results = this.Invoke("GetMeasurePointByNumberExtended", new object[] { + measurePointNumber, + measurePointFlags}); + return ((ResponseGetMeasurePoint)(results[0])); + } + + /// + public void GetMeasurePointByNumberExtendedAsync(int measurePointNumber, MeasurePointInfoFlags measurePointFlags) { + this.GetMeasurePointByNumberExtendedAsync(measurePointNumber, measurePointFlags, null); + } + + /// + public void GetMeasurePointByNumberExtendedAsync(int measurePointNumber, MeasurePointInfoFlags measurePointFlags, object userState) { + if ((this.GetMeasurePointByNumberExtendedOperationCompleted == null)) { + this.GetMeasurePointByNumberExtendedOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetMeasurePointByNumberExtendedOperationCompleted); + } + this.InvokeAsync("GetMeasurePointByNumberExtended", new object[] { + measurePointNumber, + measurePointFlags}, this.GetMeasurePointByNumberExtendedOperationCompleted, userState); + } + + private void OnGetMeasurePointByNumberExtendedOperationCompleted(object arg) { + if ((this.GetMeasurePointByNumberExtendedCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetMeasurePointByNumberExtendedCompleted(this, new GetMeasurePointByNumberExtendedCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetNodeById", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetNode GetNodeById([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int nodeId) { + object[] results = this.Invoke("GetNodeById", new object[] { + nodeId}); + return ((ResponseGetNode)(results[0])); + } + + /// + public void GetNodeByIdAsync(int nodeId) { + this.GetNodeByIdAsync(nodeId, null); + } + + /// + public void GetNodeByIdAsync(int nodeId, object userState) { + if ((this.GetNodeByIdOperationCompleted == null)) { + this.GetNodeByIdOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetNodeByIdOperationCompleted); + } + this.InvokeAsync("GetNodeById", new object[] { + nodeId}, this.GetNodeByIdOperationCompleted, userState); + } + + private void OnGetNodeByIdOperationCompleted(object arg) { + if ((this.GetNodeByIdCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetNodeByIdCompleted(this, new GetNodeByIdCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetNodeByIdExtended", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetNode GetNodeByIdExtended([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int nodeId, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] NodeInfoFlags flags) { + object[] results = this.Invoke("GetNodeByIdExtended", new object[] { + nodeId, + flags}); + return ((ResponseGetNode)(results[0])); + } + + /// + public void GetNodeByIdExtendedAsync(int nodeId, NodeInfoFlags flags) { + this.GetNodeByIdExtendedAsync(nodeId, flags, null); + } + + /// + public void GetNodeByIdExtendedAsync(int nodeId, NodeInfoFlags flags, object userState) { + if ((this.GetNodeByIdExtendedOperationCompleted == null)) { + this.GetNodeByIdExtendedOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetNodeByIdExtendedOperationCompleted); + } + this.InvokeAsync("GetNodeByIdExtended", new object[] { + nodeId, + flags}, this.GetNodeByIdExtendedOperationCompleted, userState); + } + + private void OnGetNodeByIdExtendedOperationCompleted(object arg) { + if ((this.GetNodeByIdExtendedCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetNodeByIdExtendedCompleted(this, new GetNodeByIdExtendedCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetNodeByNumber", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetNode GetNodeByNumber([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int nodeNumber) { + object[] results = this.Invoke("GetNodeByNumber", new object[] { + nodeNumber}); + return ((ResponseGetNode)(results[0])); + } + + /// + public void GetNodeByNumberAsync(int nodeNumber) { + this.GetNodeByNumberAsync(nodeNumber, null); + } + + /// + public void GetNodeByNumberAsync(int nodeNumber, object userState) { + if ((this.GetNodeByNumberOperationCompleted == null)) { + this.GetNodeByNumberOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetNodeByNumberOperationCompleted); + } + this.InvokeAsync("GetNodeByNumber", new object[] { + nodeNumber}, this.GetNodeByNumberOperationCompleted, userState); + } + + private void OnGetNodeByNumberOperationCompleted(object arg) { + if ((this.GetNodeByNumberCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetNodeByNumberCompleted(this, new GetNodeByNumberCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetNodeByNumberExtended", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetNode GetNodeByNumberExtended([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int nodeNumber, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] NodeInfoFlags flags) { + object[] results = this.Invoke("GetNodeByNumberExtended", new object[] { + nodeNumber, + flags}); + return ((ResponseGetNode)(results[0])); + } + + /// + public void GetNodeByNumberExtendedAsync(int nodeNumber, NodeInfoFlags flags) { + this.GetNodeByNumberExtendedAsync(nodeNumber, flags, null); + } + + /// + public void GetNodeByNumberExtendedAsync(int nodeNumber, NodeInfoFlags flags, object userState) { + if ((this.GetNodeByNumberExtendedOperationCompleted == null)) { + this.GetNodeByNumberExtendedOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetNodeByNumberExtendedOperationCompleted); + } + this.InvokeAsync("GetNodeByNumberExtended", new object[] { + nodeNumber, + flags}, this.GetNodeByNumberExtendedOperationCompleted, userState); + } + + private void OnGetNodeByNumberExtendedOperationCompleted(object arg) { + if ((this.GetNodeByNumberExtendedCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetNodeByNumberExtendedCompleted(this, new GetNodeByNumberExtendedCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetRoomById", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetRoom GetRoomById([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int roomId) { + object[] results = this.Invoke("GetRoomById", new object[] { + roomId}); + return ((ResponseGetRoom)(results[0])); + } + + /// + public void GetRoomByIdAsync(int roomId) { + this.GetRoomByIdAsync(roomId, null); + } + + /// + public void GetRoomByIdAsync(int roomId, object userState) { + if ((this.GetRoomByIdOperationCompleted == null)) { + this.GetRoomByIdOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetRoomByIdOperationCompleted); + } + this.InvokeAsync("GetRoomById", new object[] { + roomId}, this.GetRoomByIdOperationCompleted, userState); + } + + private void OnGetRoomByIdOperationCompleted(object arg) { + if ((this.GetRoomByIdCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetRoomByIdCompleted(this, new GetRoomByIdCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetRoomByIdExtended", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetRoom GetRoomByIdExtended([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int roomId, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] RoomInfoFlags roomFlags) { + object[] results = this.Invoke("GetRoomByIdExtended", new object[] { + roomId, + roomFlags}); + return ((ResponseGetRoom)(results[0])); + } + + /// + public void GetRoomByIdExtendedAsync(int roomId, RoomInfoFlags roomFlags) { + this.GetRoomByIdExtendedAsync(roomId, roomFlags, null); + } + + /// + public void GetRoomByIdExtendedAsync(int roomId, RoomInfoFlags roomFlags, object userState) { + if ((this.GetRoomByIdExtendedOperationCompleted == null)) { + this.GetRoomByIdExtendedOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetRoomByIdExtendedOperationCompleted); + } + this.InvokeAsync("GetRoomByIdExtended", new object[] { + roomId, + roomFlags}, this.GetRoomByIdExtendedOperationCompleted, userState); + } + + private void OnGetRoomByIdExtendedOperationCompleted(object arg) { + if ((this.GetRoomByIdExtendedCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetRoomByIdExtendedCompleted(this, new GetRoomByIdExtendedCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetMeasurePointList", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetMeasurePointList GetMeasurePointList() { + object[] results = this.Invoke("GetMeasurePointList", new object[0]); + return ((ResponseGetMeasurePointList)(results[0])); + } + + /// + public void GetMeasurePointListAsync() { + this.GetMeasurePointListAsync(null); + } + + /// + public void GetMeasurePointListAsync(object userState) { + if ((this.GetMeasurePointListOperationCompleted == null)) { + this.GetMeasurePointListOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetMeasurePointListOperationCompleted); + } + this.InvokeAsync("GetMeasurePointList", new object[0], this.GetMeasurePointListOperationCompleted, userState); + } + + private void OnGetMeasurePointListOperationCompleted(object arg) { + if ((this.GetMeasurePointListCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetMeasurePointListCompleted(this, new GetMeasurePointListCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetNodeList", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetNodeList GetNodeList() { + object[] results = this.Invoke("GetNodeList", new object[0]); + return ((ResponseGetNodeList)(results[0])); + } + + /// + public void GetNodeListAsync() { + this.GetNodeListAsync(null); + } + + /// + public void GetNodeListAsync(object userState) { + if ((this.GetNodeListOperationCompleted == null)) { + this.GetNodeListOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetNodeListOperationCompleted); + } + this.InvokeAsync("GetNodeList", new object[0], this.GetNodeListOperationCompleted, userState); + } + + private void OnGetNodeListOperationCompleted(object arg) { + if ((this.GetNodeListCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetNodeListCompleted(this, new GetNodeListCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetNodeListExtended", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetNodeList GetNodeListExtended([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] NodeInfoFlags flags) { + object[] results = this.Invoke("GetNodeListExtended", new object[] { + flags}); + return ((ResponseGetNodeList)(results[0])); + } + + /// + public void GetNodeListExtendedAsync(NodeInfoFlags flags) { + this.GetNodeListExtendedAsync(flags, null); + } + + /// + public void GetNodeListExtendedAsync(NodeInfoFlags flags, object userState) { + if ((this.GetNodeListExtendedOperationCompleted == null)) { + this.GetNodeListExtendedOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetNodeListExtendedOperationCompleted); + } + this.InvokeAsync("GetNodeListExtended", new object[] { + flags}, this.GetNodeListExtendedOperationCompleted, userState); + } + + private void OnGetNodeListExtendedOperationCompleted(object arg) { + if ((this.GetNodeListExtendedCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetNodeListExtendedCompleted(this, new GetNodeListExtendedCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetMeasurePointConsumption", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetMeasurePointConsumption GetMeasurePointConsumption([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int measurePointId, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] System.DateTime startDate, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] System.DateTime endDate, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] DeviceDataType dataType) { + object[] results = this.Invoke("GetMeasurePointConsumption", new object[] { + measurePointId, + startDate, + endDate, + dataType}); + return ((ResponseGetMeasurePointConsumption)(results[0])); + } + + /// + public void GetMeasurePointConsumptionAsync(int measurePointId, System.DateTime startDate, System.DateTime endDate, DeviceDataType dataType) { + this.GetMeasurePointConsumptionAsync(measurePointId, startDate, endDate, dataType, null); + } + + /// + public void GetMeasurePointConsumptionAsync(int measurePointId, System.DateTime startDate, System.DateTime endDate, DeviceDataType dataType, object userState) { + if ((this.GetMeasurePointConsumptionOperationCompleted == null)) { + this.GetMeasurePointConsumptionOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetMeasurePointConsumptionOperationCompleted); + } + this.InvokeAsync("GetMeasurePointConsumption", new object[] { + measurePointId, + startDate, + endDate, + dataType}, this.GetMeasurePointConsumptionOperationCompleted, userState); + } + + private void OnGetMeasurePointConsumptionOperationCompleted(object arg) { + if ((this.GetMeasurePointConsumptionCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetMeasurePointConsumptionCompleted(this, new GetMeasurePointConsumptionCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetMeasurePointTotals", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetMeasurePointTotals GetMeasurePointTotals([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int measurePointId, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] System.DateTime startDate, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] System.DateTime endDate) { + object[] results = this.Invoke("GetMeasurePointTotals", new object[] { + measurePointId, + startDate, + endDate}); + return ((ResponseGetMeasurePointTotals)(results[0])); + } + + /// + public void GetMeasurePointTotalsAsync(int measurePointId, System.DateTime startDate, System.DateTime endDate) { + this.GetMeasurePointTotalsAsync(measurePointId, startDate, endDate, null); + } + + /// + public void GetMeasurePointTotalsAsync(int measurePointId, System.DateTime startDate, System.DateTime endDate, object userState) { + if ((this.GetMeasurePointTotalsOperationCompleted == null)) { + this.GetMeasurePointTotalsOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetMeasurePointTotalsOperationCompleted); + } + this.InvokeAsync("GetMeasurePointTotals", new object[] { + measurePointId, + startDate, + endDate}, this.GetMeasurePointTotalsOperationCompleted, userState); + } + + private void OnGetMeasurePointTotalsOperationCompleted(object arg) { + if ((this.GetMeasurePointTotalsCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetMeasurePointTotalsCompleted(this, new GetMeasurePointTotalsCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/ExportMeasurePointDataToXml80020", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseExportMeasurePointDataToXml80020 ExportMeasurePointDataToXml80020([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int measurePointId, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] System.DateTime startDate, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] System.DateTime endDate) { + object[] results = this.Invoke("ExportMeasurePointDataToXml80020", new object[] { + measurePointId, + startDate, + endDate}); + return ((ResponseExportMeasurePointDataToXml80020)(results[0])); + } + + /// + public void ExportMeasurePointDataToXml80020Async(int measurePointId, System.DateTime startDate, System.DateTime endDate) { + this.ExportMeasurePointDataToXml80020Async(measurePointId, startDate, endDate, null); + } + + /// + public void ExportMeasurePointDataToXml80020Async(int measurePointId, System.DateTime startDate, System.DateTime endDate, object userState) { + if ((this.ExportMeasurePointDataToXml80020OperationCompleted == null)) { + this.ExportMeasurePointDataToXml80020OperationCompleted = new System.Threading.SendOrPostCallback(this.OnExportMeasurePointDataToXml80020OperationCompleted); + } + this.InvokeAsync("ExportMeasurePointDataToXml80020", new object[] { + measurePointId, + startDate, + endDate}, this.ExportMeasurePointDataToXml80020OperationCompleted, userState); + } + + private void OnExportMeasurePointDataToXml80020OperationCompleted(object arg) { + if ((this.ExportMeasurePointDataToXml80020Completed != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.ExportMeasurePointDataToXml80020Completed(this, new ExportMeasurePointDataToXml80020CompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetMeasurePointElectricPower", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetMeasurePointElectricPower GetMeasurePointElectricPower([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int measurePointId, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] System.DateTime startDate, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] System.DateTime endDate, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] ElectricDataKind dataKind, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] ElectricPowerAveraging averagingInterval) { + object[] results = this.Invoke("GetMeasurePointElectricPower", new object[] { + measurePointId, + startDate, + endDate, + dataKind, + averagingInterval}); + return ((ResponseGetMeasurePointElectricPower)(results[0])); + } + + /// + public void GetMeasurePointElectricPowerAsync(int measurePointId, System.DateTime startDate, System.DateTime endDate, ElectricDataKind dataKind, ElectricPowerAveraging averagingInterval) { + this.GetMeasurePointElectricPowerAsync(measurePointId, startDate, endDate, dataKind, averagingInterval, null); + } + + /// + public void GetMeasurePointElectricPowerAsync(int measurePointId, System.DateTime startDate, System.DateTime endDate, ElectricDataKind dataKind, ElectricPowerAveraging averagingInterval, object userState) { + if ((this.GetMeasurePointElectricPowerOperationCompleted == null)) { + this.GetMeasurePointElectricPowerOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetMeasurePointElectricPowerOperationCompleted); + } + this.InvokeAsync("GetMeasurePointElectricPower", new object[] { + measurePointId, + startDate, + endDate, + dataKind, + averagingInterval}, this.GetMeasurePointElectricPowerOperationCompleted, userState); + } + + private void OnGetMeasurePointElectricPowerOperationCompleted(object arg) { + if ((this.GetMeasurePointElectricPowerCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetMeasurePointElectricPowerCompleted(this, new GetMeasurePointElectricPowerCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + [System.Web.Services.Protocols.SoapDocumentMethodAttribute("http://www.lers.ru/website/api/GetMeasurePointDeviceErrors", Use=System.Web.Services.Description.SoapBindingUse.Literal, ParameterStyle=System.Web.Services.Protocols.SoapParameterStyle.Bare)] + [return: System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] + public ResponseGetMeasurePointDeviceErrors GetMeasurePointDeviceErrors([System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] int measurePointId, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] System.DateTime startDate, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] System.DateTime endDate, [System.Xml.Serialization.XmlElementAttribute(Namespace="http://www.lers.ru/website/api")] DeviceDataType dataTypes) { + object[] results = this.Invoke("GetMeasurePointDeviceErrors", new object[] { + measurePointId, + startDate, + endDate, + dataTypes}); + return ((ResponseGetMeasurePointDeviceErrors)(results[0])); + } + + /// + public void GetMeasurePointDeviceErrorsAsync(int measurePointId, System.DateTime startDate, System.DateTime endDate, DeviceDataType dataTypes) { + this.GetMeasurePointDeviceErrorsAsync(measurePointId, startDate, endDate, dataTypes, null); + } + + /// + public void GetMeasurePointDeviceErrorsAsync(int measurePointId, System.DateTime startDate, System.DateTime endDate, DeviceDataType dataTypes, object userState) { + if ((this.GetMeasurePointDeviceErrorsOperationCompleted == null)) { + this.GetMeasurePointDeviceErrorsOperationCompleted = new System.Threading.SendOrPostCallback(this.OnGetMeasurePointDeviceErrorsOperationCompleted); + } + this.InvokeAsync("GetMeasurePointDeviceErrors", new object[] { + measurePointId, + startDate, + endDate, + dataTypes}, this.GetMeasurePointDeviceErrorsOperationCompleted, userState); + } + + private void OnGetMeasurePointDeviceErrorsOperationCompleted(object arg) { + if ((this.GetMeasurePointDeviceErrorsCompleted != null)) { + System.Web.Services.Protocols.InvokeCompletedEventArgs invokeArgs = ((System.Web.Services.Protocols.InvokeCompletedEventArgs)(arg)); + this.GetMeasurePointDeviceErrorsCompleted(this, new GetMeasurePointDeviceErrorsCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)); + } + } + + /// + public new void CancelAsync(object userState) { + base.CancelAsync(userState); + } + + private bool IsLocalFileSystemWebService(string url) { + if (((url == null) + || (url == string.Empty))) { + return false; + } + System.Uri wsUri = new System.Uri(url); + if (((wsUri.Port >= 1024) + && (string.Compare(wsUri.Host, "localHost", System.StringComparison.OrdinalIgnoreCase) == 0))) { + return true; + } + return false; + } + } + + /// + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ResponseGetMeasurePoint))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ResponseGetNode))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ResponseGetRoom))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ResponseGetMeasurePointList))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ResponseGetNodeList))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ResponseGetMeasurePointConsumption))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ResponseGetMeasurePointTotals))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ResponseExportMeasurePointDataToXml80020))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ResponseGetMeasurePointElectricPower))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ResponseGetMeasurePointDeviceErrors))] + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class Response { + + private string errorMessageField; + + private ErrorCode errorCodeField; + + /// + public string ErrorMessage { + get { + return this.errorMessageField; + } + set { + this.errorMessageField = value; + } + } + + /// + public ErrorCode ErrorCode { + get { + return this.errorCodeField; + } + set { + this.errorCodeField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum ErrorCode { + + /// + None, + + /// + AuthorizationError, + + /// + UserMessage, + + /// + UnhandledException, + + /// + IncorrectRequest, + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class Room { + + private int idField; + + private string personalAccountNumberField; + + private string titleField; + + private byte residentCountField; + + private float areaField; + + private RoomType typeField; + + private MeasurePoint[] measurePointsField; + + private Equipment[] countersField; + + /// + public int Id { + get { + return this.idField; + } + set { + this.idField = value; + } + } + + /// + public string PersonalAccountNumber { + get { + return this.personalAccountNumberField; + } + set { + this.personalAccountNumberField = value; + } + } + + /// + public string Title { + get { + return this.titleField; + } + set { + this.titleField = value; + } + } + + /// + public byte ResidentCount { + get { + return this.residentCountField; + } + set { + this.residentCountField = value; + } + } + + /// + public float Area { + get { + return this.areaField; + } + set { + this.areaField = value; + } + } + + /// + public RoomType Type { + get { + return this.typeField; + } + set { + this.typeField = value; + } + } + + /// + public MeasurePoint[] MeasurePoints { + get { + return this.measurePointsField; + } + set { + this.measurePointsField = value; + } + } + + /// + public Equipment[] Counters { + get { + return this.countersField; + } + set { + this.countersField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum RoomType { + + /// + Living, + + /// + Nonresidential, + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class MeasurePoint { + + private int idField; + + private string titleField; + + private string fullTitleField; + + private string addressField; + + private SystemType systemTypeField; + + private MeasurePointType typeField; + + private System.Nullable numberField; + + private string commentField; + + private MeasurePointState stateField; + + private bool isDoublePipeHotWaterSystemField; + + private Equipment deviceField; + + private Equipment counterField; + + private bool isTwoChannelsField; + + private CustomAttributeCodeValue[] attributesField; + + /// + public int Id { + get { + return this.idField; + } + set { + this.idField = value; + } + } + + /// + public string Title { + get { + return this.titleField; + } + set { + this.titleField = value; + } + } + + /// + public string FullTitle { + get { + return this.fullTitleField; + } + set { + this.fullTitleField = value; + } + } + + /// + public string Address { + get { + return this.addressField; + } + set { + this.addressField = value; + } + } + + /// + public SystemType SystemType { + get { + return this.systemTypeField; + } + set { + this.systemTypeField = value; + } + } + + /// + public MeasurePointType Type { + get { + return this.typeField; + } + set { + this.typeField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Number { + get { + return this.numberField; + } + set { + this.numberField = value; + } + } + + /// + public string Comment { + get { + return this.commentField; + } + set { + this.commentField = value; + } + } + + /// + public MeasurePointState State { + get { + return this.stateField; + } + set { + this.stateField = value; + } + } + + /// + public bool IsDoublePipeHotWaterSystem { + get { + return this.isDoublePipeHotWaterSystemField; + } + set { + this.isDoublePipeHotWaterSystemField = value; + } + } + + /// + public Equipment Device { + get { + return this.deviceField; + } + set { + this.deviceField = value; + } + } + + /// + public Equipment Counter { + get { + return this.counterField; + } + set { + this.counterField = value; + } + } + + /// + public bool IsTwoChannels { + get { + return this.isTwoChannelsField; + } + set { + this.isTwoChannelsField = value; + } + } + + /// + public CustomAttributeCodeValue[] Attributes { + get { + return this.attributesField; + } + set { + this.attributesField = value; + } + } + } + + /// + [System.FlagsAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum SystemType { + + /// + None = 1, + + /// + Heat = 2, + + /// + HotWater = 4, + + /// + ColdWater = 8, + + /// + Steam = 16, + + /// + Gas = 32, + + /// + Electricity = 64, + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum MeasurePointType { + + /// + Regular, + + /// + Communal, + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum MeasurePointState { + + /// + None, + + /// + Normal, + + /// + Warning, + + /// + Error, + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class Equipment { + + private EquipmentModel modelField; + + private string serialNumberField; + + private string commentField; + + private System.Nullable lastCalibrationDateField; + + private System.Nullable scheduledCalibrationDateField; + + /// + public EquipmentModel Model { + get { + return this.modelField; + } + set { + this.modelField = value; + } + } + + /// + public string SerialNumber { + get { + return this.serialNumberField; + } + set { + this.serialNumberField = value; + } + } + + /// + public string Comment { + get { + return this.commentField; + } + set { + this.commentField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable LastCalibrationDate { + get { + return this.lastCalibrationDateField; + } + set { + this.lastCalibrationDateField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable ScheduledCalibrationDate { + get { + return this.scheduledCalibrationDateField; + } + set { + this.scheduledCalibrationDateField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class EquipmentModel { + + private int idField; + + private string titleField; + + private string longTitleField; + + private byte calibrationIntervalField; + + /// + public int Id { + get { + return this.idField; + } + set { + this.idField = value; + } + } + + /// + public string Title { + get { + return this.titleField; + } + set { + this.titleField = value; + } + } + + /// + public string LongTitle { + get { + return this.longTitleField; + } + set { + this.longTitleField = value; + } + } + + /// + public byte CalibrationInterval { + get { + return this.calibrationIntervalField; + } + set { + this.calibrationIntervalField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class CustomAttributeCodeValue { + + private string attributeCodeField; + + private string attributeValueField; + + /// + public string AttributeCode { + get { + return this.attributeCodeField; + } + set { + this.attributeCodeField = value; + } + } + + /// + public string AttributeValue { + get { + return this.attributeValueField; + } + set { + this.attributeValueField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class NodeSytemsInformation { + + private MeasurePoint[] allMeasurePointsField; + + /// + public MeasurePoint[] AllMeasurePoints { + get { + return this.allMeasurePointsField; + } + set { + this.allMeasurePointsField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ServiceCompany { + + private int idField; + + private string titleField; + + /// + public int Id { + get { + return this.idField; + } + set { + this.idField = value; + } + } + + /// + public string Title { + get { + return this.titleField; + } + set { + this.titleField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class Serviceman { + + private int idField; + + private string nameField; + + /// + public int Id { + get { + return this.idField; + } + set { + this.idField = value; + } + } + + /// + public string Name { + get { + return this.nameField; + } + set { + this.nameField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class Customer { + + private int idField; + + private string titleField; + + private bool isNaturalPersonField; + + private string vatIdField; + + /// + public int Id { + get { + return this.idField; + } + set { + this.idField = value; + } + } + + /// + public string Title { + get { + return this.titleField; + } + set { + this.titleField = value; + } + } + + /// + public bool IsNaturalPerson { + get { + return this.isNaturalPersonField; + } + set { + this.isNaturalPersonField = value; + } + } + + /// + public string VatId { + get { + return this.vatIdField; + } + set { + this.vatIdField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class Node { + + private int idField; + + private string titleField; + + private string addressField; + + private System.Nullable numberField; + + private string commentField; + + private string responsibleNameField; + + private string responsiblePhoneField; + + private NodeType typeField; + + private Customer customerField; + + private Serviceman servicemanField; + + private ServiceCompany serviceCompanyField; + + private NodeSytemsInformation systemsField; + + private Room[] roomsField; + + private CustomAttributeCodeValue[] attributesField; + + /// + public int Id { + get { + return this.idField; + } + set { + this.idField = value; + } + } + + /// + public string Title { + get { + return this.titleField; + } + set { + this.titleField = value; + } + } + + /// + public string Address { + get { + return this.addressField; + } + set { + this.addressField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Number { + get { + return this.numberField; + } + set { + this.numberField = value; + } + } + + /// + public string Comment { + get { + return this.commentField; + } + set { + this.commentField = value; + } + } + + /// + public string ResponsibleName { + get { + return this.responsibleNameField; + } + set { + this.responsibleNameField = value; + } + } + + /// + public string ResponsiblePhone { + get { + return this.responsiblePhoneField; + } + set { + this.responsiblePhoneField = value; + } + } + + /// + public NodeType Type { + get { + return this.typeField; + } + set { + this.typeField = value; + } + } + + /// + public Customer Customer { + get { + return this.customerField; + } + set { + this.customerField = value; + } + } + + /// + public Serviceman Serviceman { + get { + return this.servicemanField; + } + set { + this.servicemanField = value; + } + } + + /// + public ServiceCompany ServiceCompany { + get { + return this.serviceCompanyField; + } + set { + this.serviceCompanyField = value; + } + } + + /// + public NodeSytemsInformation Systems { + get { + return this.systemsField; + } + set { + this.systemsField = value; + } + } + + /// + public Room[] Rooms { + get { + return this.roomsField; + } + set { + this.roomsField = value; + } + } + + /// + public CustomAttributeCodeValue[] Attributes { + get { + return this.attributesField; + } + set { + this.attributesField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum NodeType { + + /// + None, + + /// + Node, + + /// + House, + } + + /// + [System.Xml.Serialization.XmlIncludeAttribute(typeof(WaterConsumptionRecord))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(GasConsumptionRecord))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ElectricConsumptionRecord))] + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public abstract partial class MeasurePointConsumptionRecord { + + private ResourceKind resourceKindField; + + private System.DateTime dateTimeField; + + /// + public ResourceKind ResourceKind { + get { + return this.resourceKindField; + } + set { + this.resourceKindField = value; + } + } + + /// + public System.DateTime DateTime { + get { + return this.dateTimeField; + } + set { + this.dateTimeField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum ResourceKind { + + /// + Water, + + /// + Electricity, + + /// + Gas, + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class WaterConsumptionRecord : MeasurePointConsumptionRecord { + + private System.Nullable workTimeField; + + private System.Nullable stopDurationField; + + private System.Nullable flowUnderrunDurationField; + + private System.Nullable flowOverrunDurationField; + + private System.Nullable tempDiffLowDurationField; + + private System.Nullable noPowerDurationField; + + private System.Nullable incidentDurationField; + + private System.Nullable saturatedSteamDurationField; + + private System.Nullable t_inField; + + private System.Nullable t_outField; + + private System.Nullable t_deltaField; + + private System.Nullable t_cwField; + + private System.Nullable t_outdoorField; + + private System.Nullable m_inField; + + private System.Nullable m_outField; + + private System.Nullable m_deltaField; + + private System.Nullable q_inField; + + private System.Nullable q_outField; + + private System.Nullable q_deltaField; + + private System.Nullable p_inField; + + private System.Nullable p_outField; + + private System.Nullable p_deltaField; + + private System.Nullable v_inField; + + private System.Nullable v_outField; + + private System.Nullable v_deltaField; + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable WorkTime { + get { + return this.workTimeField; + } + set { + this.workTimeField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable StopDuration { + get { + return this.stopDurationField; + } + set { + this.stopDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable FlowUnderrunDuration { + get { + return this.flowUnderrunDurationField; + } + set { + this.flowUnderrunDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable FlowOverrunDuration { + get { + return this.flowOverrunDurationField; + } + set { + this.flowOverrunDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable TempDiffLowDuration { + get { + return this.tempDiffLowDurationField; + } + set { + this.tempDiffLowDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable NoPowerDuration { + get { + return this.noPowerDurationField; + } + set { + this.noPowerDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable IncidentDuration { + get { + return this.incidentDurationField; + } + set { + this.incidentDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable SaturatedSteamDuration { + get { + return this.saturatedSteamDurationField; + } + set { + this.saturatedSteamDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable T_in { + get { + return this.t_inField; + } + set { + this.t_inField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable T_out { + get { + return this.t_outField; + } + set { + this.t_outField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable T_delta { + get { + return this.t_deltaField; + } + set { + this.t_deltaField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable T_cw { + get { + return this.t_cwField; + } + set { + this.t_cwField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable T_outdoor { + get { + return this.t_outdoorField; + } + set { + this.t_outdoorField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable M_in { + get { + return this.m_inField; + } + set { + this.m_inField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable M_out { + get { + return this.m_outField; + } + set { + this.m_outField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable M_delta { + get { + return this.m_deltaField; + } + set { + this.m_deltaField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Q_in { + get { + return this.q_inField; + } + set { + this.q_inField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Q_out { + get { + return this.q_outField; + } + set { + this.q_outField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Q_delta { + get { + return this.q_deltaField; + } + set { + this.q_deltaField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable P_in { + get { + return this.p_inField; + } + set { + this.p_inField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable P_out { + get { + return this.p_outField; + } + set { + this.p_outField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable P_delta { + get { + return this.p_deltaField; + } + set { + this.p_deltaField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable V_in { + get { + return this.v_inField; + } + set { + this.v_inField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable V_out { + get { + return this.v_outField; + } + set { + this.v_outField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable V_delta { + get { + return this.v_deltaField; + } + set { + this.v_deltaField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class GasConsumptionRecord : MeasurePointConsumptionRecord { + + private System.Nullable workTimeField; + + private System.Nullable tField; + + private System.Nullable t_outdoorField; + + private System.Nullable pField; + + private System.Nullable vField; + + private System.Nullable v_stdField; + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable WorkTime { + get { + return this.workTimeField; + } + set { + this.workTimeField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable T { + get { + return this.tField; + } + set { + this.tField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable T_outdoor { + get { + return this.t_outdoorField; + } + set { + this.t_outdoorField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable P { + get { + return this.pField; + } + set { + this.pField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable V { + get { + return this.vField; + } + set { + this.vField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable V_std { + get { + return this.v_stdField; + } + set { + this.v_stdField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ElectricConsumptionRecord : MeasurePointConsumptionRecord { + + private System.Nullable normalOperationDurationField; + + private System.Nullable apField; + + private System.Nullable anField; + + private System.Nullable rpField; + + private System.Nullable rnField; + + private System.Nullable ap1Field; + + private System.Nullable an1Field; + + private System.Nullable rp1Field; + + private System.Nullable rn1Field; + + private System.Nullable ap2Field; + + private System.Nullable an2Field; + + private System.Nullable rp2Field; + + private System.Nullable rn2Field; + + private System.Nullable ap3Field; + + private System.Nullable an3Field; + + private System.Nullable rp3Field; + + private System.Nullable rn3Field; + + private System.Nullable ap4Field; + + private System.Nullable an4Field; + + private System.Nullable rp4Field; + + private System.Nullable rn4Field; + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable NormalOperationDuration { + get { + return this.normalOperationDurationField; + } + set { + this.normalOperationDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Ap { + get { + return this.apField; + } + set { + this.apField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable An { + get { + return this.anField; + } + set { + this.anField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rp { + get { + return this.rpField; + } + set { + this.rpField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rn { + get { + return this.rnField; + } + set { + this.rnField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Ap1 { + get { + return this.ap1Field; + } + set { + this.ap1Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable An1 { + get { + return this.an1Field; + } + set { + this.an1Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rp1 { + get { + return this.rp1Field; + } + set { + this.rp1Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rn1 { + get { + return this.rn1Field; + } + set { + this.rn1Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Ap2 { + get { + return this.ap2Field; + } + set { + this.ap2Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable An2 { + get { + return this.an2Field; + } + set { + this.an2Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rp2 { + get { + return this.rp2Field; + } + set { + this.rp2Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rn2 { + get { + return this.rn2Field; + } + set { + this.rn2Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Ap3 { + get { + return this.ap3Field; + } + set { + this.ap3Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable An3 { + get { + return this.an3Field; + } + set { + this.an3Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rp3 { + get { + return this.rp3Field; + } + set { + this.rp3Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rn3 { + get { + return this.rn3Field; + } + set { + this.rn3Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Ap4 { + get { + return this.ap4Field; + } + set { + this.ap4Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable An4 { + get { + return this.an4Field; + } + set { + this.an4Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rp4 { + get { + return this.rp4Field; + } + set { + this.rp4Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rn4 { + get { + return this.rn4Field; + } + set { + this.rn4Field = value; + } + } + } + + /// + [System.Xml.Serialization.XmlIncludeAttribute(typeof(WaterTotalsRecord))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(GasTotalsRecord))] + [System.Xml.Serialization.XmlIncludeAttribute(typeof(ElectricTotalsRecord))] + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class MeasurePointTotalsRecord { + + private ResourceKind resourceKindField; + + private System.DateTime dateTimeField; + + /// + public ResourceKind ResourceKind { + get { + return this.resourceKindField; + } + set { + this.resourceKindField = value; + } + } + + /// + public System.DateTime DateTime { + get { + return this.dateTimeField; + } + set { + this.dateTimeField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class WaterTotalsRecord : MeasurePointTotalsRecord { + + private System.Nullable workTimeField; + + private System.Nullable stopDurationField; + + private System.Nullable flowUnderrunDurationField; + + private System.Nullable flowOverrunDurationField; + + private System.Nullable tempDiffLowDurationField; + + private System.Nullable noPowerDurationField; + + private System.Nullable incidentDurationField; + + private System.Nullable saturatedSteamDurationField; + + private System.Nullable m_inField; + + private System.Nullable m_outField; + + private System.Nullable q_inField; + + private System.Nullable q_outField; + + private System.Nullable q_deltaField; + + private System.Nullable v_inField; + + private System.Nullable v_outField; + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable WorkTime { + get { + return this.workTimeField; + } + set { + this.workTimeField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable StopDuration { + get { + return this.stopDurationField; + } + set { + this.stopDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable FlowUnderrunDuration { + get { + return this.flowUnderrunDurationField; + } + set { + this.flowUnderrunDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable FlowOverrunDuration { + get { + return this.flowOverrunDurationField; + } + set { + this.flowOverrunDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable TempDiffLowDuration { + get { + return this.tempDiffLowDurationField; + } + set { + this.tempDiffLowDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable NoPowerDuration { + get { + return this.noPowerDurationField; + } + set { + this.noPowerDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable IncidentDuration { + get { + return this.incidentDurationField; + } + set { + this.incidentDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable SaturatedSteamDuration { + get { + return this.saturatedSteamDurationField; + } + set { + this.saturatedSteamDurationField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable M_in { + get { + return this.m_inField; + } + set { + this.m_inField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable M_out { + get { + return this.m_outField; + } + set { + this.m_outField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Q_in { + get { + return this.q_inField; + } + set { + this.q_inField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Q_out { + get { + return this.q_outField; + } + set { + this.q_outField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Q_delta { + get { + return this.q_deltaField; + } + set { + this.q_deltaField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable V_in { + get { + return this.v_inField; + } + set { + this.v_inField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable V_out { + get { + return this.v_outField; + } + set { + this.v_outField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class GasTotalsRecord : MeasurePointTotalsRecord { + + private System.Nullable workTimeField; + + private System.Nullable vField; + + private System.Nullable v_stdField; + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable WorkTime { + get { + return this.workTimeField; + } + set { + this.workTimeField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable V { + get { + return this.vField; + } + set { + this.vField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable V_std { + get { + return this.v_stdField; + } + set { + this.v_stdField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ElectricTotalsRecord : MeasurePointTotalsRecord { + + private System.Nullable ap1Field; + + private System.Nullable an1Field; + + private System.Nullable rp1Field; + + private System.Nullable rn1Field; + + private System.Nullable ap2Field; + + private System.Nullable an2Field; + + private System.Nullable rp2Field; + + private System.Nullable rn2Field; + + private System.Nullable ap3Field; + + private System.Nullable an3Field; + + private System.Nullable rp3Field; + + private System.Nullable rn3Field; + + private System.Nullable ap4Field; + + private System.Nullable an4Field; + + private System.Nullable rp4Field; + + private System.Nullable rn4Field; + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Ap1 { + get { + return this.ap1Field; + } + set { + this.ap1Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable An1 { + get { + return this.an1Field; + } + set { + this.an1Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rp1 { + get { + return this.rp1Field; + } + set { + this.rp1Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rn1 { + get { + return this.rn1Field; + } + set { + this.rn1Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Ap2 { + get { + return this.ap2Field; + } + set { + this.ap2Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable An2 { + get { + return this.an2Field; + } + set { + this.an2Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rp2 { + get { + return this.rp2Field; + } + set { + this.rp2Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rn2 { + get { + return this.rn2Field; + } + set { + this.rn2Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Ap3 { + get { + return this.ap3Field; + } + set { + this.ap3Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable An3 { + get { + return this.an3Field; + } + set { + this.an3Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rp3 { + get { + return this.rp3Field; + } + set { + this.rp3Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rn3 { + get { + return this.rn3Field; + } + set { + this.rn3Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Ap4 { + get { + return this.ap4Field; + } + set { + this.ap4Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable An4 { + get { + return this.an4Field; + } + set { + this.an4Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rp4 { + get { + return this.rp4Field; + } + set { + this.rp4Field = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Rn4 { + get { + return this.rn4Field; + } + set { + this.rn4Field = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class MeasurePointElectricPowerRecord { + + private System.DateTime dateTimeField; + + private short intervalField; + + private System.Nullable ppField; + + private System.Nullable pnField; + + private System.Nullable qpField; + + private System.Nullable qnField; + + /// + public System.DateTime DateTime { + get { + return this.dateTimeField; + } + set { + this.dateTimeField = value; + } + } + + /// + public short Interval { + get { + return this.intervalField; + } + set { + this.intervalField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Pp { + get { + return this.ppField; + } + set { + this.ppField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Pn { + get { + return this.pnField; + } + set { + this.pnField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Qp { + get { + return this.qpField; + } + set { + this.qpField = value; + } + } + + /// + [System.Xml.Serialization.XmlElementAttribute(IsNullable=true)] + public System.Nullable Qn { + get { + return this.qnField; + } + set { + this.qnField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class MeasurePointDeviceErrorRecord { + + private DeviceEventArchiveType archiveTypeField; + + private short channelNumberField; + + private System.DateTime dateTimeField; + + private int codeField; + + private string descriptionField; + + private int durationField; + + /// + public DeviceEventArchiveType ArchiveType { + get { + return this.archiveTypeField; + } + set { + this.archiveTypeField = value; + } + } + + /// + public short ChannelNumber { + get { + return this.channelNumberField; + } + set { + this.channelNumberField = value; + } + } + + /// + public System.DateTime DateTime { + get { + return this.dateTimeField; + } + set { + this.dateTimeField = value; + } + } + + /// + public int Code { + get { + return this.codeField; + } + set { + this.codeField = value; + } + } + + /// + public string Description { + get { + return this.descriptionField; + } + set { + this.descriptionField = value; + } + } + + /// + public int Duration { + get { + return this.durationField; + } + set { + this.durationField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum DeviceEventArchiveType { + + /// + Common, + + /// + HeatLeadIn, + + /// + Channel, + + /// + DiscreteInput, + + /// + DiscreteOutput, + + /// + ModeChange, + + /// + UserActions, + + /// + PowerInterruptionPeriods, + + /// + ConfigChanges, + + /// + Diagnostics, + + /// + Incidents, + + /// + MonthPowerInterruptions, + + /// + DayPowerInterruptions, + + /// + DiagnosticNonAffectingRecording, + + /// + IncidentsAffectingRecording, + + /// + DaySummarizedIncidents, + + /// + HourSummarizedIncidents, + + /// + CommonEvents, + + /// + IndividualEvents, + + /// + PrevAndCurrMonthIncidents, + + /// + PeripherialErrors, + + /// + Failures, + + /// + Errors, + + /// + Warnings, + + /// + Messages, + + /// + BasicLog, + + /// + SystemLog, + + /// + HotWaterLog, + + /// + System1, + + /// + System2, + + /// + System3, + + /// + Status5, + + /// + Status6, + + /// + StatusSys, + + /// + HardwareIncidents, + + /// + HardwareEvents, + + /// + HsEvents, + + /// + HmEvents, + + /// + HeatSystemEvents, + + /// + AdditionalIncidents, + + /// + SensorFailures, + + /// + HeatSystemIncidents, + + /// + HardwareFailures, + + /// + HeatSystemStatus, + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ResponseGetMeasurePoint : Response { + + private MeasurePoint measurePointField; + + /// + public MeasurePoint MeasurePoint { + get { + return this.measurePointField; + } + set { + this.measurePointField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ResponseGetNode : Response { + + private Node nodeField; + + /// + public Node Node { + get { + return this.nodeField; + } + set { + this.nodeField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ResponseGetRoom : Response { + + private Room roomField; + + /// + public Room Room { + get { + return this.roomField; + } + set { + this.roomField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ResponseGetMeasurePointList : Response { + + private MeasurePoint[] measurePointListField; + + /// + public MeasurePoint[] MeasurePointList { + get { + return this.measurePointListField; + } + set { + this.measurePointListField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ResponseGetNodeList : Response { + + private Node[] nodeListField; + + /// + public Node[] NodeList { + get { + return this.nodeListField; + } + set { + this.nodeListField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ResponseGetMeasurePointConsumption : Response { + + private MeasurePointConsumptionRecord[] dataField; + + /// + public MeasurePointConsumptionRecord[] Data { + get { + return this.dataField; + } + set { + this.dataField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ResponseGetMeasurePointTotals : Response { + + private MeasurePointTotalsRecord[] totalsField; + + /// + public MeasurePointTotalsRecord[] Totals { + get { + return this.totalsField; + } + set { + this.totalsField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ResponseExportMeasurePointDataToXml80020 : Response { + + private string xmlField; + + /// + public string Xml { + get { + return this.xmlField; + } + set { + this.xmlField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ResponseGetMeasurePointElectricPower : Response { + + private MeasurePointElectricPowerRecord[] electricPowerField; + + /// + public MeasurePointElectricPowerRecord[] ElectricPower { + get { + return this.electricPowerField; + } + set { + this.electricPowerField = value; + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public partial class ResponseGetMeasurePointDeviceErrors : Response { + + private MeasurePointDeviceErrorRecord[] monthArchiveField; + + private MeasurePointDeviceErrorRecord[] dayArchiveField; + + private MeasurePointDeviceErrorRecord[] hourArchiveField; + + /// + public MeasurePointDeviceErrorRecord[] MonthArchive { + get { + return this.monthArchiveField; + } + set { + this.monthArchiveField = value; + } + } + + /// + public MeasurePointDeviceErrorRecord[] DayArchive { + get { + return this.dayArchiveField; + } + set { + this.dayArchiveField = value; + } + } + + /// + public MeasurePointDeviceErrorRecord[] HourArchive { + get { + return this.hourArchiveField; + } + set { + this.hourArchiveField = value; + } + } + } + + /// + [System.FlagsAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum MeasurePointInfoFlags { + + /// + None = 1, + + /// + Equipment = 2, + + /// + ContractConsumption = 4, + + /// + ConsumptionLimit = 8, + + /// + Attributes = 16, + } + + /// + [System.FlagsAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum NodeInfoFlags { + + /// + None = 1, + + /// + Systems = 2, + + /// + Customer = 4, + + /// + Serviceman = 8, + + /// + ServiceCompany = 16, + + /// + NodeGroups = 32, + + /// + BalanceFormulae = 64, + + /// + DiagSettings = 128, + + /// + Reports = 256, + + /// + Suppliers = 512, + + /// + Equipment = 1024, + + /// + Rooms = 2048, + + /// + ContractTemperature = 4096, + + /// + Signaling = 8192, + + /// + Attributes = 16384, + } + + /// + [System.FlagsAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum RoomInfoFlags { + + /// + None = 1, + + /// + MeasurePoints = 2, + + /// + Counters = 4, + + /// + ContractConsumption = 8, + } + + /// + [System.FlagsAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum DeviceDataType { + + /// + None = 1, + + /// + DeviceConfig = 2, + + /// + Events = 4, + + /// + Current = 8, + + /// + Interval = 16, + + /// + Month = 32, + + /// + Day = 64, + + /// + Hour = 128, + + /// + PowerProfile = 256, + + /// + Totals = 512, + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum ElectricDataKind { + + /// + Raw, + + /// + Real, + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Xml", "4.6.1055.0")] + [System.SerializableAttribute()] + [System.Xml.Serialization.XmlTypeAttribute(Namespace="http://www.lers.ru/website/api")] + public enum ElectricPowerAveraging { + + /// + Default, + + /// + Hourly, + + /// + Daily, + + /// + HalfHourly, + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void LoginCompletedEventHandler(object sender, LoginCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class LoginCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal LoginCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public Response Result { + get { + this.RaiseExceptionIfNecessary(); + return ((Response)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void LogoutCompletedEventHandler(object sender, LogoutCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class LogoutCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal LogoutCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public Response Result { + get { + this.RaiseExceptionIfNecessary(); + return ((Response)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetMeasurePointByIdCompletedEventHandler(object sender, GetMeasurePointByIdCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetMeasurePointByIdCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetMeasurePointByIdCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetMeasurePoint Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetMeasurePoint)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetMeasurePointByIdExtendedCompletedEventHandler(object sender, GetMeasurePointByIdExtendedCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetMeasurePointByIdExtendedCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetMeasurePointByIdExtendedCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetMeasurePoint Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetMeasurePoint)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetMeasurePointByNumberCompletedEventHandler(object sender, GetMeasurePointByNumberCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetMeasurePointByNumberCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetMeasurePointByNumberCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetMeasurePoint Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetMeasurePoint)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetMeasurePointByNumberExtendedCompletedEventHandler(object sender, GetMeasurePointByNumberExtendedCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetMeasurePointByNumberExtendedCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetMeasurePointByNumberExtendedCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetMeasurePoint Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetMeasurePoint)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetNodeByIdCompletedEventHandler(object sender, GetNodeByIdCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetNodeByIdCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetNodeByIdCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetNode Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetNode)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetNodeByIdExtendedCompletedEventHandler(object sender, GetNodeByIdExtendedCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetNodeByIdExtendedCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetNodeByIdExtendedCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetNode Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetNode)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetNodeByNumberCompletedEventHandler(object sender, GetNodeByNumberCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetNodeByNumberCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetNodeByNumberCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetNode Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetNode)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetNodeByNumberExtendedCompletedEventHandler(object sender, GetNodeByNumberExtendedCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetNodeByNumberExtendedCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetNodeByNumberExtendedCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetNode Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetNode)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetRoomByIdCompletedEventHandler(object sender, GetRoomByIdCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetRoomByIdCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetRoomByIdCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetRoom Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetRoom)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetRoomByIdExtendedCompletedEventHandler(object sender, GetRoomByIdExtendedCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetRoomByIdExtendedCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetRoomByIdExtendedCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetRoom Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetRoom)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetMeasurePointListCompletedEventHandler(object sender, GetMeasurePointListCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetMeasurePointListCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetMeasurePointListCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetMeasurePointList Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetMeasurePointList)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetNodeListCompletedEventHandler(object sender, GetNodeListCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetNodeListCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetNodeListCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetNodeList Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetNodeList)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetNodeListExtendedCompletedEventHandler(object sender, GetNodeListExtendedCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetNodeListExtendedCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetNodeListExtendedCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetNodeList Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetNodeList)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetMeasurePointConsumptionCompletedEventHandler(object sender, GetMeasurePointConsumptionCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetMeasurePointConsumptionCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetMeasurePointConsumptionCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetMeasurePointConsumption Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetMeasurePointConsumption)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetMeasurePointTotalsCompletedEventHandler(object sender, GetMeasurePointTotalsCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetMeasurePointTotalsCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetMeasurePointTotalsCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetMeasurePointTotals Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetMeasurePointTotals)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void ExportMeasurePointDataToXml80020CompletedEventHandler(object sender, ExportMeasurePointDataToXml80020CompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class ExportMeasurePointDataToXml80020CompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal ExportMeasurePointDataToXml80020CompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseExportMeasurePointDataToXml80020 Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseExportMeasurePointDataToXml80020)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetMeasurePointElectricPowerCompletedEventHandler(object sender, GetMeasurePointElectricPowerCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetMeasurePointElectricPowerCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetMeasurePointElectricPowerCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetMeasurePointElectricPower Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetMeasurePointElectricPower)(this.results[0])); + } + } + } + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + public delegate void GetMeasurePointDeviceErrorsCompletedEventHandler(object sender, GetMeasurePointDeviceErrorsCompletedEventArgs e); + + /// + [System.CodeDom.Compiler.GeneratedCodeAttribute("System.Web.Services", "4.6.1055.0")] + [System.Diagnostics.DebuggerStepThroughAttribute()] + [System.ComponentModel.DesignerCategoryAttribute("code")] + public partial class GetMeasurePointDeviceErrorsCompletedEventArgs : System.ComponentModel.AsyncCompletedEventArgs { + + private object[] results; + + internal GetMeasurePointDeviceErrorsCompletedEventArgs(object[] results, System.Exception exception, bool cancelled, object userState) : + base(exception, cancelled, userState) { + this.results = results; + } + + /// + public ResponseGetMeasurePointDeviceErrors Result { + get { + this.RaiseExceptionIfNecessary(); + return ((ResponseGetMeasurePointDeviceErrors)(this.results[0])); + } + } + } +} + +#pragma warning restore 1591 \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/Reference.map b/WebApiSamples/C#/TestLersApi/Web References/LersApi/Reference.map new file mode 100644 index 0000000..56e1b92 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/Reference.map @@ -0,0 +1,7 @@ + + + + + + + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/Response.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/Response.datasource new file mode 100644 index 0000000..e8d862f --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/Response.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.Response, Web References.LersApi.Reference.cs.dll, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseExportMeasurePointDataToXml80020.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseExportMeasurePointDataToXml80020.datasource new file mode 100644 index 0000000..c41baf4 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseExportMeasurePointDataToXml80020.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseExportMeasurePointDataToXml80020, Web References.LersApi.Reference.cs.dll, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePoint.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePoint.datasource new file mode 100644 index 0000000..0457ea3 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePoint.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseGetMeasurePoint, Web References.LersApi.Reference.cs.dll, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointByNumber.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointByNumber.datasource new file mode 100644 index 0000000..6332bd8 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointByNumber.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseGetMeasurePointByNumber, Web References.LersApi.Reference.cs, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointConsumption.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointConsumption.datasource new file mode 100644 index 0000000..f20a09c --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointConsumption.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseGetMeasurePointConsumption, Web References.LersApi.Reference.cs.dll, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointDeviceErrors.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointDeviceErrors.datasource new file mode 100644 index 0000000..a8633fe --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointDeviceErrors.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseGetMeasurePointDeviceErrors, Web References.LersApi.Reference.cs.dll, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointElectricPower.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointElectricPower.datasource new file mode 100644 index 0000000..3a8295d --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointElectricPower.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseGetMeasurePointElectricPower, Web References.LersApi.Reference.cs.dll, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointList.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointList.datasource new file mode 100644 index 0000000..c9fcdf7 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointList.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseGetMeasurePointList, Web References.LersApi.Reference.cs.dll, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointTotals.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointTotals.datasource new file mode 100644 index 0000000..6680c54 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetMeasurePointTotals.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseGetMeasurePointTotals, Web References.LersApi.Reference.cs.dll, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetNode.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetNode.datasource new file mode 100644 index 0000000..8c7c3b1 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetNode.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseGetNode, Web References.LersApi.Reference.cs.dll, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetNodeByNumber.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetNodeByNumber.datasource new file mode 100644 index 0000000..0222f63 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetNodeByNumber.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseGetNodeByNumber, Web References.LersApi.Reference.cs, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetNodeList.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetNodeList.datasource new file mode 100644 index 0000000..0d100b6 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetNodeList.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseGetNodeList, Web References.LersApi.Reference.cs.dll, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetRoom.datasource b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetRoom.datasource new file mode 100644 index 0000000..81282c1 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/ResponseGetRoom.datasource @@ -0,0 +1,10 @@ + + + + TestLersApi.LersApi.ResponseGetRoom, Web References.LersApi.Reference.cs.dll, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/api.disco b/WebApiSamples/C#/TestLersApi/Web References/LersApi/api.disco new file mode 100644 index 0000000..026e4be --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/api.disco @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/Web References/LersApi/api.wsdl b/WebApiSamples/C#/TestLersApi/Web References/LersApi/api.wsdl new file mode 100644 index 0000000..48a6fa9 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/Web References/LersApi/api.wsdl @@ -0,0 +1,1266 @@ + + + +<b>Описание:</b></br> +</br> +Программный интерфейс для взаимодействия с системой ЛЭРС УЧЕТ. <a href='http://support.lers.ru/docs/x/LIAM' >Документация по API.</a><br/> +<br/> +Для работы с веб-службой необходима поддержка технологии передачи cookie на клиентской стороне.</br> +</br> +Основная часть функций требует наличия активного сеанса, который создается с помощью аутентификации (функция Login). После успешной аутентификации, идентификация клиента происходит по средствам технологии передачи cookie.<br/> +<br/> +Сеанс можно закрыть либо явно (функция Logout), либо он будет закрыт автоматически при отсутствии активности в течение часа.<br/> +<br/> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Вход в систему. + + + + + Выход из системы + + + + + Получает точку учета по идентификатору. + + + + + Получает точку учета с расширенной информацией по идентификатору. + + + + + Получает точку учета по номеру. + + + + + Получает точку учета с расширенной информацией по номеру. + + + + + Получает объект учета по идентификатору. + + + + + Получает объект учета с расширенной информацией по идентификатору. + + + + + Получает объект учета по номеру. + + + + + Получает объект учета с расширенной информацией по номеру. + + + + + Получает помещение дома по идентификатору. + + + + + Получает помещение дома с дополнительной информацией по идентификатору. + + + + + Получает список точек учета, доступных для учетной записи. + + + + + Получает список объектов учета, доступных для учетной записи. + + + + + Получает список объектов учета с расширенной информацией, доступных для учетной записи. + + + + + Получает потребление по точке учета. + + + + + Получает показания по точке учета. + + + + + Экспорт данных потребления по точке учета в формате Xml 80020. + + + + + Получает данные профиля электрической мощности по точке учета. + + + + + Получает данные профиля электрической мощности по точке учета. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +<b>Описание:</b></br> +</br> +Программный интерфейс для взаимодействия с системой ЛЭРС УЧЕТ. <a href='http://support.lers.ru/docs/x/LIAM' >Документация по API.</a><br/> +<br/> +Для работы с веб-службой необходима поддержка технологии передачи cookie на клиентской стороне.</br> +</br> +Основная часть функций требует наличия активного сеанса, который создается с помощью аутентификации (функция Login). После успешной аутентификации, идентификация клиента происходит по средствам технологии передачи cookie.<br/> +<br/> +Сеанс можно закрыть либо явно (функция Logout), либо он будет закрыт автоматически при отсутствии активности в течение часа.<br/> +<br/> + + + + + + + + \ No newline at end of file diff --git a/WebApiSamples/C#/TestLersApi/app.config b/WebApiSamples/C#/TestLersApi/app.config new file mode 100644 index 0000000..acca441 --- /dev/null +++ b/WebApiSamples/C#/TestLersApi/app.config @@ -0,0 +1,15 @@ + + + + +
+ + + + + + http://localhost:54025/api.asmx + + + + \ No newline at end of file diff --git a/WebApiSamples/NotificationSample/Notification.xml b/WebApiSamples/NotificationSample/Notification.xml new file mode 100644 index 0000000..4aaf815 --- /dev/null +++ b/WebApiSamples/NotificationSample/Notification.xml @@ -0,0 +1,6 @@ + + + Внимание. С 23.06.2013 по 30.06.2013 не будет горячей воды. + До 27.03.2013 необходимо ввести показания по своим счетчикам. +
Внимание. 20.06.2013 в 16:00 будет собрание обслуживающих.
+
\ No newline at end of file diff --git a/WebApiSamples/PowerShell/TestLersApi.ps1 b/WebApiSamples/PowerShell/TestLersApi.ps1 new file mode 100644 index 0000000..03ac11e --- /dev/null +++ b/WebApiSamples/PowerShell/TestLersApi.ps1 @@ -0,0 +1,44 @@ +$url = "http://localhost:54025/Api.asmx" + +# Создаем прокси класс для работы со службой +$webservice = New-WebServiceProxy -uri $url + +# Устанавливаем куки-контейнер, необходим для авторизации пользователя +$webservice.CookieContainer = New-Object System.Net.CookieContainer + +# Входим в систему ЛЭРС УЧЕТ +$response1 = $webservice.Login('demo', 'demo') + +# Если произошла ошибка, прекращаем работу +if($response1.IsError -eq $true) +{ + Write-Host $response1.ErrorMessage + exit +} + +# Получаем список точек учета +$response2 = $webservice.GetMeasurePointList() + +# Если список пустой, выходим +if($response2.MeasurePointList.Length -le 0) +{ + Write-Host 'Список точек учета пуст' + exit +} + +# Получаем потребление по первой точке учета из списка +$endDate = [DateTime]::Today + +$startDate = New-Object DateTime($endDate.Year, $endDate.Month, 1) + +$response3 = $webservice.GetMeasurePointConsumption($response2.MeasurePointList[0].Id, $startDate, $endDate, 'Day') + +# Если список пустой, выходим +if($response3.Data.Length -le 0) +{ + Write-Host 'По точке учета нет данных потребления' + exit +} + +# Выводим сообщение со значением T_in за первую метку времени +Write-Host $response3.Data[0].DateTime ': ' $response3.Data[0].T_in diff --git a/WebApiSamples/WebCustomization/FooterRight.ascx b/WebApiSamples/WebCustomization/FooterRight.ascx new file mode 100644 index 0000000..c486cce --- /dev/null +++ b/WebApiSamples/WebCustomization/FooterRight.ascx @@ -0,0 +1,24 @@ +<%@ Control Language="C#" AutoEventWireup="true" ClassName="Lers.Web.Client.FooterRight" %> + +<%@ Import Namespace="Lers.Web.Api" %> + + + + + + diff --git a/WebApiSamples/WebCustomization/SimplePage.html b/WebApiSamples/WebCustomization/SimplePage.html new file mode 100644 index 0000000..a4542e2 --- /dev/null +++ b/WebApiSamples/WebCustomization/SimplePage.html @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/WebApiSamples/WebCustomization/TestPage.aspx b/WebApiSamples/WebCustomization/TestPage.aspx new file mode 100644 index 0000000..f6549ac --- /dev/null +++ b/WebApiSamples/WebCustomization/TestPage.aspx @@ -0,0 +1,7 @@ +<%@ Page Title=" " Language="C#" AutoEventWireup="true" MasterPageFile="~/Main.Master" %> + + + + + + \ No newline at end of file